首頁 > 資料庫 > mysql教程 > 机房收费系统之组合查询BUG

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

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2016-06-07 16:03:39
原創
1048 人瀏覽過

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

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

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

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

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

第一种方法:

\

\

第二种方法:
\

\


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

第一种拼接:

select * from T_Line where status !=&#39;正在上机&#39; and cardNo >&#39;0&#39; or cardNo < &#39;5&#39;
登入後複製

\

第二种拼接:
select * from (select * from T_Line where status!=&#39;正在上机&#39;)as T_Line where cardNo > &#39;0&#39; or cardNo < &#39;5&#39;
登入後複製

\

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

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

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

相關標籤:
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
javascript - 鍊家地圖搜房效果怎麼實現
來自於 1970-01-01 08:00:00
0
0
0
想實現地圖找房功能?有沒這樣的教學?
來自於 1970-01-01 08:00:00
0
0
0
Nginx upstream能否跨機房?
來自於 1970-01-01 08:00:00
0
0
0
Prisma 的房間管理系統
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板