当前位置: 首页 > news >正文

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 查询优化器行为的,禁用“派生表条件下推”.....

最终查询生效,算是临时解决吧.......

相关文章:

  • 数字电子技术基础(五十九)——脉冲触发的触发器
  • (8)python开发经验
  • 开源安全大模型Foundation-Sec-8B实操
  • Vim编辑器命令模式操作指南
  • python打卡day28
  • Florence2代码实战
  • STM32IIC实战-OLED模板
  • 端口443在git bash向github推送时的步骤
  • 手机打电话时由对方DTMF响应切换多级IVR语音应答(二)
  • C++中析构函数不设为virtual导致内存泄漏示例
  • 使用glsl 来做视频矫正
  • 单细胞转录组(2)单细胞测序原理
  • 【Linux网络与网络编程】12.NAT技术内网穿透代理服务
  • 【前端基础】HTML元素隐藏的四个方法(display设置为none、visibikity设置为hidden、rgba设置颜色、opacity设置透明度)
  • DeepSeek 赋能社会科学:解锁研究新范式
  • 现在市面上三大常用的拓客软件好用吗?
  • 机器学习,深度学习,神经网络,深度神经网络之间有何区别?
  • PostgreSQL内幕剖析——结构与架构
  • C++类与对象--1 特性一:封装
  • 深入浅出IIC协议 - 从总线原理到FPGA实战开发 -- 第一篇:I2C总线协议深度解剖
  • 菲律宾中期选举结果揭晓,马科斯与杜特尔特家族重回“权力的游戏”
  • 特朗普指控FBI前局长“暗示刺杀总统”,“8647”藏着什么玄机?
  • 孟夏韵评《无序的学科》丨误读与重构的文化漂流
  • 机器人为啥热衷“搞体育”,经济日报:是向加速融入日常生活发起的冲锋
  • 刘小涛任江苏省委副书记
  • 选址江南制造总局旧址,上海工业博物馆建设有新进展