Mysql 8.0.32 union all 创建视图后中文模糊查询失效
记录问题,最近在使用union all聚合了三张表的数据,创建视图作为查询主表,发现字段值为中文的筛选无法生效..........
sql示例:
CREATE OR REPLACE VIEW test_view AS SELECTid,`name`,location_address AS address,type,"1" AS data_type,COALESCE ( update_time, create_time ) AS update_time
FROMtable_1 UNION ALL
SELECTid,`name`,location_address AS address,type,"2" AS data_type,COALESCE ( update_time, create_time ) AS update_time
FROMtable_2;
发现除了中文外,数值的都能筛选出来,查询后发现说是数据库的字符集得弄成utf8mb4,但是这个基本是没问题的,并且这个查看也没问题
-- 查看当前会话的字符集设置
SHOW VARIABLES LIKE 'character_set%';
查询视图字符集也没毛病
SHOW FULL COLUMNS FROM test_view;
通过上述基本排除了是字符集的原因,另外又将两个表单独创建并对中文字段值进行筛选,发现单表时是没问题的,但是一使用union的聚合,筛选就失效了.............
最后网上不断的查,才找到了说8.0.32的版本 union有问题,升级或更换版本才能解决这个,但是不想再重装了,使用临时的方案处理
SET GLOBAL optimizer_switch='derived_condition_pushdown=off';
全局关闭,调整 MySQL 查询优化器行为的,禁用“派生表条件下推”.....
最终查询生效,算是临时解决吧.......