下午在调试程序的时候一个诡异的现象,删除单据后被删除的单据依然显示在列表中,查看后台数据库,删除标记已经被置为Y。心里一阵纳闷,于是打断点跟踪,将程序加载时拼出来的语句放在SQL里执行了一把,结果还是把已经删除的记录给查出来了;然后就对着那个查询语句做修改,改来改去就是改不正确,明明在查询条件中对删除的字段做了过滤,但是还是能查出来。后来再将过滤条件一个一个添加,然后查询的土方法中终于发现了猫腻,嘿嘿 犯错误很低级 就是在过滤条件中添加了or关键字,但是没有加括号...
犯错的语句:
修改后的语句
其实要是把语句简化为 select * from aaa where delete = 'N' or 1=1 我想应该很快能定位这个错误
犯错的语句:
select * from aaa
where Delete!='Y'
and Date between '2010-11-17 00:00:00' and '2010-12-17 23:59:59'
and To in (select Stock from StockCtrl where User='106')
or From in (select Stock from StockCtrl where User='106')
order by Date desc
修改后的语句
select * from aaa
where Delete!='Y'
and Date between '2010-11-17 00:00:00' and '2010-12-17 23:59:59'
and (To in (select Stock from StockCtrl where User='106')
or From in (select Stock from StockCtrl where User='106'))
order by Date desc
其实要是把语句简化为 select * from aaa where delete = 'N' or 1=1 我想应该很快能定位这个错误
本文记录了一个在SQL查询过程中遇到的问题——已删除的记录仍然出现在查询结果中。问题的原因在于查询语句中的逻辑运算符使用不当,导致了意料之外的结果。通过对SQL语句的逐步调试与修正,最终解决了这个问题。
3184

被折叠的 条评论
为什么被折叠?



