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

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

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

http://www.xdnf.cn/news/6838.html

相关文章:

  • CF803G Periodic RMQ Problem Solution
  • shell脚本之条件判断,循环控制,exit详解
  • 系统架构设计(八):三层架构
  • Java 原生网络编程(BIO | NIO | Reactor 模式)
  • Redlock算法和底层源码分析
  • 【背包dp-----分组背包】------(标准的分组背包【可以不装满的 最大价值】)
  • 基于STM32的INA226电压电流检测仪
  • 全栈项目搭建指南:Nuxt.js + Node.js + MongoDB
  • 阿里巴巴视觉生成大模型1.2.1版本深度部署指南
  • PyQt5 的使用
  • 系统架构设计(六):面向对象设计
  • ChatGPT + DeepSeek 联合润色的 Prompt 模板指令合集,用来润色SCI论文太香了!
  • W5500使用ioLibrary库创建TCP客户端
  • 使用 Vue Tour 封装一个统一的页面引导组件
  • 为 Spring Boot 应用程序构建 CI/CD 流水线
  • 【Linux】共享内存
  • LeetCode 33. 搜索旋转排序数组:二分查找的边界艺术
  • 创建型模式
  • python 自动化教程
  • 布隆过滤器和布谷鸟过滤器
  • Python 在黎曼几何中的应用
  • OGGMA 21c 微服务 (MySQL) 安装避坑指南
  • .NET Core 中 Swagger 配置详解:常用配置与实战技巧
  • 技术测评:小型单文件加密工具的功能解析
  • 线性回归策略
  • Linux zip、unzip 压缩和解压
  • 冒泡排序-java
  • stack和queue简单模拟实现
  • 一个可拖拉实现列表排序的WPF开源控件
  • 使用lvm进行磁盘分区