反向like,在使用EXISTS关键字时遇到的问题

本人刚刚上岗开发,这个问题对大佬们来说可能不是事,但确实困扰我好久。

需求

一个查询 1.查询条件有金额(F_JE)的范围查找,F_FXZBBH等。 2.要求根据组织机构(F_ZZJG)分级展示,如果下级组织机构满足条件,则也要把所有上级组织机构展示出来。 3.表的主键为F_FXZBBH和F_ZZJG。

根据以上条件写出sql:

sql 复制代码
SELECT F_FXZBBH,F_FXZBMC,F_ZZJG,F_JE FROM TABLEXX A 
WHERE 1=1  
AND F_FXZBBH = '001000100010' 
AND EXISTS  (SELECT 1 FROM TABLEXX B WHERE  B.F_ZZJG LIKE A.F_ZZJG||'%'  AND F_JE >= 1 AND F_JE <= 61590) 

测试时发现问题

出现了一条金额为0的最下级组织机构的数据。数据库里有好多金额为0的数据,但此处别的都没有出现,只出现了F_ZZJG为100016001000100的这一条

经过不断测试,我发现当sql里的条件F_JE >= 1 改为F_JE >=50013 时,就不会再有F_ZZJG为100016001000100的这一条数据了。当F_JE >=50012时,就会出现这一条数据。于是我去数据库里查找F_ZZJG为100016001000100对应的数据

发现问题,因为表的主键为F_FXZBBH和F_ZZJG。F_ZZJG为100016001000100对应了两条数据 其中一条满足了 F_JE >= 1 AND F_JE <= 61590 所以根据EXISTS,把它及它所有上级的数据都查出来了,此时的F_ZZJG为100016001000100和它所有上级其实都是被查出来F_FXZBBH不同的两条数据的,但EXISTS外又限制了F_FXZBBH = '001000100010',所以JE为50012的那几条数据被过滤了,只剩下满足*F_FXZBBH = '001000100010'*金额为0的数据了。

解决方案

sql 复制代码
SELECT F_FXZBBH,F_FXZBMC,F_ZZJG,F_JE FROM TABLEXX A 
WHERE 1=1  
AND F_FXZBBH = '001000100010' 
AND EXISTS  (SELECT 1 FROM TABLEXX B WHERE A.F_FXZBBH=B.F_FXZBBH AND B.F_ZZJG LIKE A.F_ZZJG||'%'  AND F_JE >= 1 AND F_JE <= 61590) 

在EXISTS中添加A.F_FXZBBH=B.F_FXZBBH

结论

在EXISTS关键字中的WHERE条件中,务必根据唯一性约束,将所有用于确定唯一性的条件都关联上。

相关推荐
三毛200425 分钟前
玳瑁的嵌入式日记D33-0908(SQL数据库)
jvm·数据库·sql
TDengine (老段)2 小时前
TDengine 选择函数 Last() 用户手册
大数据·数据库·sql·物联网·时序数据库·tdengine·涛思数据
心 一4 小时前
Web安全基石:深入理解与防御SQL注入漏洞
sql·安全·web安全
林熙蕾LXL5 小时前
SQL Server——基本操作
数据库·sql
FLS1687 小时前
Kali搭建sqli-labs靶场
linux·sql·安全·网络安全
007php0077 小时前
某大厂MySQL面试之SQL注入触点发现与SQLMap测试
数据库·python·sql·mysql·面试·职场和发展·golang
Ultipa12 小时前
查询语言的进化:SQL之后,为什么是GQL?数据世界正在改变
数据库·sql·图数据库·gql
LB211212 小时前
SQL隐式链接显式连接
大数据·数据库·sql
GM_82815 小时前
【Go项目基建】GORM框架实现SQL校验拦截器(完整源码+详解)
sql·golang·拦截器·gorm·慢查询·持久层基建
半夏陌离1 天前
SQL 拓展指南:不同数据库差异对比(MySQL/Oracle/SQL Server 基础区别)
大数据·数据库·sql·mysql·oracle·数据库架构