MySQL查询条件OR导致模糊查询失效

起因:查出来的列表数据,通过查询条件过滤,发现过滤条件并不起作用

检查发现:where查询条件里面有or的过滤条件,用来进行权限控制,模糊查询条件本来是起效果的,但是OR的条件一执行,就有多了些数据

代码:

sql 复制代码
SELECT
 item_apply_id,
 ....
FROM
 loan_item_apply 
WHERE
 item_apply_title LIKE '%临海%' 
 AND ( createBy =10000131273521 
				OR item_apply_a =10000131273521 
				OR item_apply_b =10000131273521 
				OR createBy = 0 
				OR createBy IS NULL 
				OR createBy IN ( SELECT UNDERUSERID FROM sys_user_under WHERE USERID =10000131273521) ) 
 AND doc_status != 1 
--下面的查询条件一添加,就会再多出来一些符合下面查询条件的数据
 OR EXISTS ( SELECT 1 FROM bl_project_approval bpa 
						 WHERE bpa.check_person LIKE CONCAT( '%',10000131273521, '%' ) 
						 AND bpa.project_approval_id = loan_item_apply.project_approval_id ) 

期望的结果:先查出来所有符合要求的,然后再根据过滤条件去过滤,所以这里做的处理是,再套一层,把这个查询出来的结果当成一个临时表,再select这个临时表,用过滤条件过滤这个临时表的数据

⚠️⚠️⚠️

查询条件有OR的条件的话,需要注意

相关推荐
大鹏说大话21 小时前
深入理解 MySQL 查询语句的执行顺序与函数调用机制
数据库·mysql
SQL必知必会21 小时前
精通递归 CTE:SQL 的盗梦空间
数据库·sql
知识分享小能手21 小时前
SQL Server 2019入门学习教程,从入门到精通,SQL Server 2019 游标 — 语法知识点及使用方法详解(14)
数据库·学习·sqlserver
青春:一叶知秋21 小时前
【Redis存储】Redis客户端
java·数据库·redis
独泪了无痕21 小时前
通过Homebrew安装Redis指南
数据库·redis·缓存
数据知道21 小时前
PostgreSQL:如何把PostgreSQL变成时序数据库(TimescaleDB)
数据库·postgresql·时序数据库
崎岖Qiu21 小时前
【MySQL | 第11篇】一条SQL查询语句的执行全流程简析
数据库·后端·sql·mysql
w***29851 天前
Knife4j文档请求异常(基于SpringBoot3,查找原因并解决)
java·服务器·数据库
砚边数影1 天前
运营商网管系统重构:如何解决海量投诉数据下的“查询延迟”与“写入瓶颈”?
网络·数据库·时序数据库·kingbase·kingbasees·数据库平替用金仓·金仓数据库
shsh2001 天前
mybatis plus打印sql日志
数据库·sql·mybatis