机房收费系统之组合查询BUG

原创
2016-06-07 16:03:39 739浏览

声明:以下内容只对在学生上机记录查询(组合查询)只查询已下机记录,操作员工作记录(组合查询)只查询已注销记录的同学适用! 说是BUG,其实这也不是一个BUG,只是一个不小心容易犯的错误,而且不注意的话还真发现不了。下面就给大家详细的讲讲: 在机房

声明:以下内容只对在学生上机记录查询(组合查询)只查询已下机记录,操作员工作记录(组合查询)只查询已注销记录的同学适用!

说是BUG,其实这也不是一个BUG,只是一个不小心容易犯的错误,而且不注意的话还真发现不了。下面就给大家详细的讲讲:

在机房收费系统中有三个组合查询:学生基本信息查询、学生上机记录查询、操作员工作记录查询;其中的学生上机记录查询,我个人认为应该只查询出已经下机的记录,正在上机的记录不应该被查询出来;操作员工作记录也是同样的。

如果你跟我也是一样的想法,那就接着看看我们的实现方式是否一样吧:组合查询的SQL语句都是拼接字符串拼出来的,但是我们拼出来的正确吗?

第一种方法:

\

\

第二种方法:
\

\


一样的数据,一样的组合查询却出来了不同的查询结果?怎么会这样呢?肯定是我们自己的问题。我们都知道在组合查询中的SQL查询语句是一个个条件拼接出来的,但是我们拼接的到底正确不正确呢?

第一种拼接:

select * from T_Line where status !='正在上机' and cardNo >'0' or cardNo 

\

第二种拼接:
select * from (select * from T_Line where status!='正在上机')as T_Line where cardNo > '0' or cardNo 

\

对于第一种拼接,就是特别简单的在后面加一个条件进行拼接,我相信一定有人跟我犯过同样的错误哦!其实只要我们把SQL语句写出来,就能很容易的看见自己错在什么地方:如果所有的条件之间都是用“and”连接,也能查询出正确的结果,但是,当我们用“or”连接条件的时候呢?

对于第二种拼接,首先是用一个子查询查询出满足“已下机”这个条件的结果作为一个临时变,然后再从这个临时表中查询我们想要查询的数据,这样,不管后面的条件是“and”还是“or”都不会查询出正在上机的记录。

经过上面简单的讲解,相信大家都明白自己的BUG出现在什么地方,如果还有不明白,或者更好的解决方案,欢迎私下讨论......

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。