mysql的like查询中“-”通配符的干扰以及解决办法
mysql 查询 以及 解决办法 like 通配符 干扰
2023-09-27 14:22:13 时间
一 问题描述
1.通配符%”是 MySQL 中最常用的通配符,它能代表任何长度的字符串,字符串的长度可以为 0。例如,a%b
表示以字母 a 开头,以字母 b 结尾的任意长度的字符串。该字符串可以代表 ab、acb、accb、accrb 等字符串。
2.“_”只能代表单个字符,字符的长度不能为 0。例如,a_b
可以代表 acb、adb、aub 等字符串。
3.问题描述:
sql语句中通过like模糊查询“_z”,"_c"结尾的数据,但是不是_c,_z结尾的数据,也查询出来了。
select
t.device_code deviceGroupNoCode, t.point_code dataPointCode,
t.total_date totalDate,
count(point_code) as totalNum, sum(duration_time) durationTime
from (
SELECT LEFT(gl_data_point_code, 7 ) AS device_code,gl_data_point_code, point_code, restore_time,
case when DATE_FORMAT(ifnull(restore_time,'2022-04-11'),'%Y-%m-%d')!='2022-04-11' then '2022-04-11' else '2022-04-11' end as total_date,
MAX(TIMESTAMPDIFF(second,IF(occurrence_time > concat('2022-04-11',' 00:00:00'),occurrence_time,concat('2022-04-11',' 00:00:00')) ,
IF(restore_time < concat('2022-04-11',' 23:59:59'),restore_time,concat(date_add('2022-04-11',interval 1 day),' 00:00:00')))) duration_time
FROM iip_acc_warn_information, gl_data_point_mapping
WHERE occurrence_time <= concat('2022-04-11',' 23:59:59') AND ( restore_time IS NULL OR restore_time >= concat('2022-04-11',' 00:00:00') )
AND ( warn_id IN ( SELECT id FROM iip_acc_prod_event_def ) OR (warn_id not IN ( SELECT id FROM iip_acc_prod_event_def ) and STATUS = 1 ) )
and ( gl_data_point_code LIKE '30KYQ10%_C%' or gl_data_point_code LIKE '30KYQ10%_Z%' ) AND data_point_code = point_code GROUP BY point_code, restore_time
) t GROUP BY device_code, point_code, total_date
4.原因分析:
自定义编码中的_C, _z和mysql自定义的通配符"_",冲突了,gl_data_point_code LIKE '30KYQ10%_C%' or gl_data_point_code LIKE '30KYQ10%_Z%'
可以理解为:30KYQ10% 忽略不看_C,表示在含有单个c,或者单个Z的数据就会被搜索到;并不是按照我们设想的要查找“下划线C”结尾的数据。
这个时候就需要将通配符“_”进行转义,如“\_”,加上“\”进行转义。表示含有“下划线C”才能匹配到。
不加“\”的“_”,则_ 表示通配符_
加“\”的“_”,则表示下划线
5.解决办法
mysql怎么转义字符_MySQL的转义字符"\"_半泽和莉娜的博客-CSDN博客
二 案例2
1.表中数据:
2.查询
相关文章
- 万万没想到,我在夜市地摊解决了MySQL临时表空间难题~~
- (6) MySQL慢查询日志的使用
- mysql:索引原理与慢查询优化
- mybatis插入数据时返回主键以及MySQL根据时间区间查询问题总结
- mysql 将多个查询结果合并成一行
- mysql数据库限制多次登录失败,限定用户重试时间
- mysql数据索引,加快查询速度
- mysql中没有自增主键查询时自动设置
- MySQL 中如何定位 DDL 被阻塞的问题
- Mysql模糊查询like效率,以及更高效的写法
- mysql查询今天、昨天、7天、近30天、本月、上一月 数据
- mysql中的union用法以及子查询综合应用
- mysql LIMIT 子句用法及原理
- MySQL里面的子查询实例
- MYSQL数据仓库infobright【备忘】
- MySQL【二】---数据库查询详细教程{查询、排序、聚合函数、分组}
- MySQL查询开销计算原理和索引失效原因
- 2022-09-02 mysql/stonedb-IN句子使用HASH优化后-查询多个字符串结果不符合预期记录
- 2022-07-13 mysql/stonedb子查询perf分析
- 2022-07-18 mysql/stonedb-exists子查询的剔除遍历处理
- MySQL 查询 limit 1000,10 和 limit 10 速度一样快吗? 深度分页如何破解
- mysql命令行操作
- 『MySQL』索引类型 normal, unique, full text
- 尖峰7月线上技术分享--Hadoop、MySQL
- MySQL · 引擎特性 · InnoDB mini transation
- mysql之mysql、mysql-devel、mysql-server
- Mysql SQL查询今天、昨天、n天内、第n天的数据
- mysql学习 | LeetCode数据库简单查询练习
- 【mysql我能讲两小时026】innodb的next-key lock 有什么作用?避免了什么问题?