博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL好习惯:编写支持可搜索的SQL
阅读量:6582 次
发布时间:2019-06-24

本文共 1428 字,大约阅读时间需要 4 分钟。

1 概述

最近维护系统时,客户经常反馈这样一个内容:要在查询列表上加上一个查询条件。这样的要求一点也不过分,并且看起来工作量也不大,不就是加一个WHERE条件嘛,但是当调试到DAL层时,立刻石化——遇到在SELECT子句中编写子查询的SQL,

SELECT SO.order_no,(SELECT SUM(SOD.good_num) FROM [StockOrderDetails] AS SOD WHERE SOD.order_id=SO.id) AS order_numFROM [StockOrder] AS SO

这样的写法缺点如下:

1>order_num不能在SELECT中继续使用

2>order_num不能在WHERE子句中使用(SELECT中的子查询不能在WHERE中使用)

3>性能问题

这里我们主要讨论第二点:order_num不能在WHERE子句中使用

2 为什么order_num不能在WHERE子句中使用?

因为SELECT语句执行的过程是:

1>. FROM

2>. WHERE
3>. GROUP BY
4>. HAVING
5>. SELECT
6>. ORDER BY

WHERE子句在SELECT子句之前执行,所以在SELECT中的列别名,WHERE中当然是不会认识的。

3.示例

业务:采购订单查询列表,需要显示订单的主信息,并且还要显示每一个订单的总的采购数量;

测试数据:

不支持可搜索的SQL:

SELECT SO.order_no,(SELECT SUM(SOD.good_num) FROM [StockOrderDetails] AS SOD WHERE SOD.order_id=SO.id) AS order_numFROM [StockOrder] AS SO

支持可搜索的SQL:

SELECT SO.order_no,ISNULL(SOD.order_num,0) AS order_numFROM [StockOrder] AS SO     LEFT JOIN     (         SELECT order_id,SUM(good_num) AS order_num FROM [StockOrderDetails]         GROUP BY order_id    ) AS SOD ON SO.id=SOD.order_idWHERE SOD.order_num>=8

当子查询相当复杂时,可以用WITH AS(子查询部分)来替换 LEFT JOIN部分:

;WITH StockOrderD AS(    SELECT order_id,SUM(good_num) AS order_num FROM [StockOrderDetails]    GROUP BY order_id)SELECT SO.order_no,ISNULL(SOD.order_num,0) AS order_numFROM [StockOrder] AS SO     LEFT JOIN StockOrderD AS SOD ON SO.id=SOD.order_idWHERE SOD.order_num>=8

4 总结

总得来说就是将过程性的思维转换为集合的思维。

本篇文章主要写给刚开始正式写SQL的朋友,在开发时注意一些SQL的写法,可以添加更多的灵活性,降低维护阶段的工作量。

转载地址:http://kzxno.baihongyu.com/

你可能感兴趣的文章
Beautiful Soup学习
查看>>
MySQL函数不能创建的解决方法
查看>>
字王·百字工程·正式启动
查看>>
POJ2348 Euclid's Game
查看>>
java并发之(4):Semaphore信号量、CounDownLatch计数锁存器和CyclicBarrier循环栅栏
查看>>
输入年月日判断是当年第几天(if判断)
查看>>
移动前端不得不了解的Meta标签
查看>>
XMLDOC的常用方法和属性
查看>>
Windows 8学习笔记(七)--Input输入设备
查看>>
2014.12.8 自定义button
查看>>
Upgrade to Python 2.7.9 on CentOS5.5
查看>>
Matlab DIP(瓦)ch10图像分割练习
查看>>
html规范整体结构
查看>>
函数的参数
查看>>
项目实战2—实现基于LVS负载均衡集群的电商网站架构
查看>>
Xen的概况
查看>>
mysql日志管理
查看>>
css中visiblity和display异同
查看>>
E - A strange lift 【数值型BFS+上下方向】
查看>>
最小生成树-prim算法模板
查看>>