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的条件的话,需要注意

相关推荐
2301_792185885 分钟前
快速熟悉后缀为yml的文件
java·linux·数据库
计算机学姐8 分钟前
基于SpringBoot的服装购物商城销售系统【协同过滤推荐算法+数据可视化统计】
java·vue.js·spring boot·mysql·信息可视化·mybatis·推荐算法
..过云雨9 分钟前
【MySQL】4. MySQL表的操作
数据库·mysql
坐吃山猪10 分钟前
Neo4j01_图数据库概念和服务器安装
服务器·数据库·oracle
数据知道22 分钟前
MongoDB 正则表达式查询:在 MongoDB 中实现模糊搜索与索引优化陷阱
数据库·mongodb·正则表达式
纤纡.28 分钟前
从 WHERE 到 OFFSET:SQL 基本查询的核心逻辑
linux·数据库·sql
ID_1800790547339 分钟前
淘宝商品详情API请求的全场景,带json数据参考
服务器·数据库·json
troublea43 分钟前
Laravel5.x核心特性全解析
数据库·spring boot·后端·mysql
青柠代码录1 小时前
【MySQL】JDBC体系中SQL处理流程详解
mysql
難釋懷1 小时前
Redis消息队列-基于Stream的消息队列
数据库·redis·缓存