mysql的like查询中“-”通配符的干扰以及解决办法

2024-05-29 07:48

本文主要是介绍mysql的like查询中“-”通配符的干扰以及解决办法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一 问题描述

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的like查询中“-”通配符的干扰以及解决办法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1013067

相关文章

sql语句字段截取方法

《sql语句字段截取方法》在MySQL中,使用SUBSTRING函数可以实现字段截取,下面给大家分享sql语句字段截取方法,感兴趣的朋友一起看看吧... 目录sql语句字段截取sql 截取表中指定字段sql语句字段截取1、在mysql中,使用SUBSTRING函数可以实现字段截取。例如,要截取一个字符串字

SQL Server身份验证模式步骤和示例代码

《SQLServer身份验证模式步骤和示例代码》SQLServer是一个广泛使用的关系数据库管理系统,通常使用两种身份验证模式:Windows身份验证和SQLServer身份验证,本文将详细介绍身份... 目录身份验证方式的概念更改身份验证方式的步骤方法一:使用SQL Server Management S

MySQL 字符串截取函数及用法详解

《MySQL字符串截取函数及用法详解》在MySQL中,字符串截取是常见的操作,主要用于从字符串中提取特定部分,MySQL提供了多种函数来实现这一功能,包括LEFT()、RIGHT()、SUBST... 目录mysql 字符串截取函数详解RIGHT(str, length):从右侧截取指定长度的字符SUBST

MySQL中的事务隔离级别详解

《MySQL中的事务隔离级别详解》在MySQL中,事务(Transaction)是一个执行单元,它要么完全执行,要么完全回滚,以保证数据的完整性和一致性,下面给大家介绍MySQL中的事务隔离级别详解,... 目录一、事务并发问题二、mysql 事务隔离级别1. READ UNCOMMITTED(读未提交)2

MySQL Workbench工具导出导入数据库方式

《MySQLWorkbench工具导出导入数据库方式》:本文主要介绍MySQLWorkbench工具导出导入数据库方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录mysql Workbench工具导出导入数据库第一步 www.chinasem.cn数据库导出第二步

一文详解如何查看本地MySQL的安装路径

《一文详解如何查看本地MySQL的安装路径》本地安装MySQL对于初学者或者开发人员来说是一项基础技能,但在安装过程中可能会遇到各种问题,:本文主要介绍如何查看本地MySQL安装路径的相关资料,需... 目录1. 如何查看本地mysql的安装路径1.1. 方法1:通过查询本地服务1.2. 方法2:通过MyS

Mysql数据库中数据的操作CRUD详解

《Mysql数据库中数据的操作CRUD详解》:本文主要介绍Mysql数据库中数据的操作(CRUD),详细描述对Mysql数据库中数据的操作(CRUD),包括插入、修改、删除数据,还有查询数据,包括... 目录一、插入数据(insert)1.插入数据的语法2.注意事项二、修改数据(update)1.语法2.有

SQL Server中的PIVOT与UNPIVOT用法具体示例详解

《SQLServer中的PIVOT与UNPIVOT用法具体示例详解》这篇文章主要给大家介绍了关于SQLServer中的PIVOT与UNPIVOT用法的具体示例,SQLServer中PIVOT和U... 目录引言一、PIVOT:将行转换为列核心作用语法结构实战示例二、UNPIVOT:将列编程转换为行核心作用语

SQL 外键Foreign Key全解析

《SQL外键ForeignKey全解析》外键是数据库表中的一列(或一组列),用于​​建立两个表之间的关联关系​​,外键的值必须匹配另一个表的主键(PrimaryKey)或唯一约束(UniqueCo... 目录1. 什么是外键?​​ ​​​​2. 外键的语法​​​​3. 外键的约束行为​​​​4. 多列外键​

MySQL精准控制Binlog日志数量的三种方案

《MySQL精准控制Binlog日志数量的三种方案》作为数据库管理员,你是否经常为服务器磁盘爆满而抓狂?Binlog就像数据库的“黑匣子”,默默记录着每一次数据变动,但若放任不管,几天内这些日志文件就... 目录 一招修改配置文件:永久生效的控制术1.定位my.cnf文件2.添加核心参数不重启热更新:高手应