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

php中文网
发布: 2016-06-07 16:03:39
原创
1194人浏览过

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

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

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

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

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

第一种方法:

\

\

第二种方法:
\

\


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

第一种拼接:

select * from T_Line where status !='正在上机' and cardNo >'0' or cardNo < '5'
登录后复制

\

第二种拼接:
select * from (select * from T_Line where status!='正在上机')as T_Line where cardNo > '0' or cardNo < '5'
登录后复制

\

Shop7z网上购物系统至尊版
Shop7z网上购物系统至尊版

Shop7z网上购物系统支持电脑版+手机版+支付宝及微信支付,支持QQ和微信一键登陆,系统集众家之所长,大气超美观页面+手机版+商品组合套餐+限时抢购秒杀+图片批量上传+淘宝数据包导入+弹出式分类菜单+不同规格不同价格+新订单邮件通知+销售报表打印与Excel输出+物流跟踪打印查询+会员积分及优惠券+邮件群发+图片在线管理+销售统计报表+五种价格体系+礼品礼券+微信公众号支付+扫码支付等等等。

Shop7z网上购物系统至尊版 2
查看详情 Shop7z网上购物系统至尊版

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

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

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

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号