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

相关推荐
猫头虎1 分钟前
2025最新OpenEuler系统安装MySQL的详细教程
linux·服务器·数据库·sql·mysql·macos·openeuler
哈库纳玛塔塔25 分钟前
放弃 MyBatis,拥抱新一代 Java 数据访问库
java·开发语言·数据库·mybatis·orm·dbvisitor
@LetsTGBot搜索引擎机器人2 小时前
2025 Telegram 最新免费社工库机器人(LetsTG可[特殊字符])搭建指南(含 Python 脚本)
数据库·搜索引擎·机器人·开源·全文检索·facebook·twitter
计算机毕设VX:Fegn08952 小时前
计算机毕业设计|基于springboot + vue动物园管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
冉冰学姐3 小时前
SSM校园排球联赛管理系统y513u(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架应用·开题报告、
Tony Bai3 小时前
【分布式系统】03 复制(上):“权威中心”的秩序 —— 主从架构、一致性与权衡
大数据·数据库·分布式·架构
wb043072014 小时前
SQL工坊不只是一个ORM框架
数据库·sql
至善迎风4 小时前
Redis完全指南:从诞生到实战
数据库·redis·缓存
QQ_4376643146 小时前
Redis协议与异步方式
数据库·redis·bootstrap
纪莫6 小时前
技术面:MySQL篇(InnoDB事务执行过程、事务隔离级别、事务并发异常)
数据库·java面试⑧股