mysql查询报错java.sql.SQLException: Illegal mix of collations for operation ‘UNION‘

1.场景

需要写一个sql,需要合并 从四张表查询查询出来的结果,需要用到 UNION ALL 对查询结果进行合并

2.sql

sql 复制代码
-- 从 unit 表中查询
select id, name, '1' as type
from unit
where name like concat('%', #{name}, '%')

UNION ALL

-- 从 system 表中查询
select id, name, '2' as type
from system
where name like concat('%', #{name}, '%')

UNION ALL

-- 从 equipment 表中查询
select id, name, '3' as type
from equipment
where name like concat('%', #{name}, '%')

UNION ALL

-- 从 measuring_point 表中查询
select id, name, '4' as type
from measuring_point
where name like concat('%', #{name}, '%')

3.查询报错

java 复制代码
java.sql.SQLException: Illegal mix of collations for operation 'UNION'

4.检查4张建表语句的排序规则是否一致

sql 复制代码
SHOW FULL COLUMNS FROM unit;
SHOW FULL COLUMNS FROM system;
SHOW FULL COLUMNS FROM equipment;
SHOW FULL COLUMNS FROM measuring_point;
sql 复制代码
CREATE TABLE `template_config_unit` (
  `id` bigint NOT NULL AUTO_INCREMENT COMMENT '主键',
  `template_name` varchar(255) COLLATE utf8mb4_general_ci NOT NULL COMMENT '机组模板名称',
  `code` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '编码',
  `type` int DEFAULT NULL COMMENT '机组类型(1:锅炉专业, 2:汽机专业, 3:电气专业, 4:环化专业)'
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=227 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='机组表';

重点关注

sql 复制代码
ENGINE=InnoDB AUTO_INCREMENT=227 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci 

5.本人遇到的问题 是排序规则不一致造成的

6.解决方案

修改表的排序规则

sql 复制代码
ALTER TABLE unit CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
ALTER TABLE system CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
ALTER TABLE equipment CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
ALTER TABLE measuring_point CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

7.最后

问题解决

相关推荐
Albert Edison几秒前
【MySQL】事务管理
数据库·mysql
计算机毕设指导63 分钟前
基于Django的本地健康宝微信小程序系统【源码文末联系】
java·后端·python·mysql·微信小程序·小程序·django
gjc5927 分钟前
MySQL无主键大表删除导致主从同步延迟的深度分析
数据库·mysql
杨了个杨898220 分钟前
Rsyslog + MySQL 实现日志集中存储
数据库·mysql
Token_w35 分钟前
Llama 3-8B-Instruct 在昇腾 NPU 上的 SGLang 性能实测
mysql·llama·sglang
better_liang44 分钟前
每日Java面试场景题知识点之-MySQL高并发数据一致性保障
mysql·高并发·java面试·数据一致性·企业级开发
码农阿豪1 小时前
MySQL 亿级大表(1.35亿条)安全添加字段实战指南
数据库·mysql·安全
典龙3301 小时前
推荐一款开源免费的AI智能数据库工具,支持连接mysql,oracle,postgresql,ssh,redis
数据库·mysql
luoluoal2 小时前
基于python的病人信息管理系统及安全策略分析(源码+文档)
python·mysql·django·毕业设计·源码
海盗12348 小时前
MySQL主从复制的配置方式
android·mysql·adb