表关联查询:utf8mb4_general_ci和utf8mb4_0900_ai_ci两种不同的校对规则在操作符‘=‘时混用了

异常信息:

复制代码
 Error querying database. Cause: java.sql.SQLException: Illegal mix of collations (utf8mb4_general_ci,IMPLICIT) and (utf8mb4_0900_ai_ci,IMPLICIT) for operation '=' ### 
复制代码
### Cause: java.sql.SQLException: Illegal mix of collations (utf8mb4_general_ci,IMPLICIT) and (utf8mb4_0900_ai_ci,IMPLICIT) for operation '=' ; uncategorized SQLException; SQL state [HY000]; error code [1267]; Illegal mix of collations (utf8mb4_general_ci,IMPLICIT) and (utf8mb4_0900_ai_ci,IMPLICIT) for operation '='; nested exception is java.sql.SQLException: Illegal mix of collations (utf8mb4_general_ci,IMPLICIT) and (utf8mb4_0900_ai_ci,IMPLICIT) for operation '='

解决方案:

校对规则(collation)决定了字符串比较和排序的方式。当两个字符串的校对规则不同时,MySQL可能无法正确比较它们,从而导致这样的错误。用户执行的是一个JOIN操作,涉及到多个表,尤其是tb_device和tb_region这两个表。根据错误提示,问题出现在某个ON子句中的列比较,可能是它们的字符集或校对规则不一致。

这个错误是由于在MySQL查询中,不同校对规则(collation)的列进行了比较导致的。以下是逐步解决方案:

1. 定位冲突的列

错误信息指出在=操作时混用了utf8mb4_general_ciutf8mb4_0900_ai_ci两种校对规则。检查以下JOIN条件中的列:

sql 复制代码
cd.device_guid = cdb.device_guid       -- 检查 device_guid 列
cdb.business_id = cb.business_id       -- 检查 business_id 列
cdb.province = cr.ad_code              -- 检查 province 和 ad_code 列

2. 查看列的校对规则

对每个涉及的列执行以下SQL,确认其字符集和校对规则:

sql 复制代码
SHOW CREATE TABLE tb_device_base;
SHOW CREATE TABLE tb_region;

3. 统一校对规则

方法一:修改表结构(永久生效)

如果确认某些列的校对规则不一致,修改它们的定义:

sql 复制代码
ALTER TABLE tb_device_base 
MODIFY COLUMN province VARCHAR(255) 
CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci;

ALTER TABLE tb_region 
MODIFY COLUMN ad_code VARCHAR(255) 
CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci;

将冲突列的校对规则改为相同值(如统一为utf8mb4_0900_ai_ci)。

方法二:在查询中强制转换校对规则

无需修改表结构,直接在查询时指定校对规则:

sql 复制代码
SELECT ...
FROM tb_device_base cdb
LEFT JOIN tb_region cr ON 
  cdb.province = cr.ad_code COLLATE utf8mb4_0900_ai_ci  -- 强制统一校对规则
...

ON子句中使用COLLATE关键字显式指定校对规则。

4. 检查数据库默认配置

确保相关表的默认字符集和校对规则一致:

sql 复制代码
-- 修改表的默认校对规则
ALTER TABLE tb_device_base 
DEFAULT CHARACTER SET utf8mb4 
COLLATE utf8mb4_0900_ai_ci;

-- 修改数据库默认校对规则
ALTER DATABASE your_database_name 
CHARACTER SET utf8mb4 
COLLATE utf8mb4_0900_ai_ci;

5. 验证修复

重新运行查询,确认错误是否消失。如果仍有问题,重复步骤2-3检查其他可能冲突的列。

注意事项

  • 备份数据:修改表结构前务必备份。
  • 性能影响utf8mb4_0900_ai_ci是更新的校对规则,提供更准确的比较,但可能略微影响性能。
  • 兼容性:确保应用程序逻辑适应校对规则变更后的字符串比较行为。

通过以上步骤,可消除因校对规则不匹配导致的查询错误。

相关推荐
-SGlow-8 小时前
MySQL相关概念和易错知识点(2)(表结构的操作、数据类型、约束)
linux·运维·服务器·数据库·mysql
水瓶_bxt10 小时前
Centos安装HAProxy搭建Mysql高可用集群负载均衡
mysql·centos·负载均衡
♡喜欢做梦10 小时前
【MySQL】深入浅出事务:保证数据一致性的核心武器
数据库·mysql
遇见你的雩风11 小时前
MySQL的认识与基本操作
数据库·mysql
dblens 数据库管理和开发工具11 小时前
MySQL新增字段DDL:锁表全解析、避坑指南与实战案例
数据库·mysql·dblens·dblens mysql·数据库连接管理
weixin_4196583111 小时前
MySQL的基础操作
数据库·mysql
Goona_12 小时前
拒绝SQL恐惧:用Python+pyqt打造任意Excel数据库查询系统
数据库·python·sql·excel·pyqt
Olrookie13 小时前
若依前后端分离版学习笔记(三)——表结构介绍
笔记·后端·mysql
rufeii15 小时前
[极客大挑战 2019]FinalSQL--布尔盲注
sql
Lemon程序馆15 小时前
今天聊聊 Mysql 的那些“锁”事!
后端·mysql