MySQL报错:MySQL Illegal mix of collations for operation 'like'

本文探讨了在MySQL5.5及以上版本中对时间字段进行模糊查询时遇到的Illegal mix of collations for operation 'like'错误,并提供了解决方案。建议使用LIKE BINARY替代LIKE以避免此问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天在对一个时间字段进行模糊查询的时候出现以下问题:

    //提示非法组合
    MySQL Illegal mix of collations for operation 'like'
问题原因:

在 MySQL 5.5 以上, 若字段类型 Type 是 time,date,datetime ,在 select时如果使用 like ‘%中文%’ 会出现 Illegal mix of collations for operation ‘like’,在编程时要对某些字段进行模糊查询时,就可能会出现时间字段 like ‘%中文%’ 这种语法。

解决:
  • MYSQL旧版没有问题。
  • MySQL 5.5 以上, 必需改成 like binary ‘%中文%’ 即可避免出现错误.
### 关于MySQL UNION操作中的字符集不匹配问题 当执行 `UNION` 操作时,如果参与查询的列具有不同的字符集或排序规则,则可能会遇到错误消息:“Illegal mix of collations”。这是因为 MySQL 要求在 `UNION` 中的所有字段必须具有相同的字符集和排序规则。 #### 错误原因分析 此错误通常发生在以下情况之一: - 查询涉及的不同表中同一名称的列定义了不同的字符集(如 `utf8mb4` 和 `latin1`)。 - 即使两个列都使用相同的基础字符集(例如 `utf8mb4`),但如果它们有不同的排序规则(collation),也会引发该错误[^1]。 #### 解决方案 可以通过显式指定统一的字符集和排序规则来解决这一问题。以下是几种常见的方法: 1. **强制转换字符集** 使用 `CONVERT()` 函数可以将某一列的数据临时转换为目标字符集。 ```sql SELECT CONVERT(column_name USING utf8mb4) AS column_name FROM table1 UNION SELECT CONVERT(column_name USING utf8mb4) AS column_name FROM table2; ``` 2. **设置一致的排序规则 (Collation)** 如果两列已经属于同一个基础字符集,但其排序规则不同,则可以在查询中通过 `COLLATE` 明确指定一个共同的排序规则。 ```sql SELECT column_name COLLATE utf8mb4_general_ci AS column_name FROM table1 UNION SELECT column_name COLLATE utf8mb4_general_ci AS column_name FROM table2; ``` 3. **修改数据库结构** 长期解决方案是对相关表格进行结构调整,使得所有涉及到的列均采用同样的字符集与排序规则。这一步骤可能需要停机维护并重新导入数据以确保一致性。 4. **全局配置调整** 可考虑更改服务器默认字符集以及新建表时自动应用的默认值。编辑 my.cnf 文件,在 `[mysqld]` 下增加如下参数即可生效: ```ini character-set-server=utf8mb4 collation-server=utf8mb4_unicode_ci ``` 完成上述任一方式后重启服务,并验证新创建的对象是否遵循预期设定。 ```sql SHOW VARIABLES LIKE 'character_set_server'; SHOW VARIABLES LIKE 'collation_server'; ``` 以上措施能够有效规避因字符编码差异而导致的操作失败情形。 ### 示例代码展示 下面提供一段综合运用前述技巧的实际案例演示如何处理此类冲突状况: ```sql -- 假设有两张分别存储英文名与中国姓名信息的表 SELECT id, name COLLATE utf8mb4_general_ci AS unified_name FROM english_names UNION SELECT id, CONVERT(name USING utf8mb4) COLLATE utf8mb4_general_ci AS unified_name FROM chinese_names; ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值