我们现在回到函数上。记得我们用
SUM
这个指令来算出所有的 Sales (营业额)吧!如果我们的需求变成是要算出每一间店 (store_name) 的营业额 (sales),那怎么办呢?在这个情况下,我们要做到两件事:第一,我们对于 store_name 及 Sales 这两个栏位都要选出。第二,我们需要确认所有的 sales 都要依照各个 store_name 来分开算。这个语法为:
SELECT "栏位1", SUM("栏位2") FROM "表格名" GROUP BY "栏位1"
在我们的示范上
Store_Information 表格
store_name
sales
date
Los Angeles
$1500
jan-05-1999
San Francisco
$300
jan-08-1999
Boston
$700
jan-08-1999
我们就打入
SELECT store_name, SUM(Sales) FROM Store_Information GROUP BY store_name
结果 :
store_name SUM(Sales)
Los Angeles $1800
San Diego $250
Boston $700
当我们选不只一个栏位,且其中至少一个栏位有包含函数的运用时,我们就需要用到 GROUP BY 这个指令。在这个情况下,我们需要确定我们有 GROUP BY 所有其他的栏位。换句话说,除了有包括函数的栏位外,我们都需要将其放在 GROUP BY 的子句中。
SQL 语句教程 (12) HAVING
那我们如何对函数产生的值来设定条件呢?举例来说,我们可能只需要知道哪些店的营业额有超过 $1,500。在这个情况下,我们不能使用
WHERE
的指令。那要怎么办呢?很幸运地,SQL 有提供一个
HAVING
的指令,而我们就可以用这个指令来达到这个目标。
HAVING
子句通常是在一个 SQL 句子的最后。一个含有 HAVING 子句的 SQL 并不一定要包含
GROUP BY
子句。HAVING
的语法如下:
SELECT "栏位1", SUM("栏位2") FROM "表格名" GROUP BY "栏位1" HAVING (函数条件)
请读者注意: GROUP BY 子句并不是一定需要的。
在我们Store_Information 表格这个例子中
Store_Information 表格
store_name
sales
date
Los Angeles
$1500
jan-05-1999
San Francisco
$300
jan-08-1999
Boston
$700
jan-08-1999
我们打入
SELECT store_name, SUM(sales) FROM Store_Information GROUP BY store_name HAVING SUM(sales) > 1500
结果 :
store_name SUM(Sales)
Los Angeles $1800
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
更新日志
- 齐秦《齐秦的世纪情歌之迷》24K GOLD [WAV+CUE][568M]
- 电子琴《汽车音响精品》5CD特效360度[WAV+CUE]
- 【古典音乐】卡拉扬《首次录音(4)》2006[FLAC+CUE整轨]
- 群星《巅峰煲碟皇·男人篇》[WAV+CUE]
- 2023年中国自研移动游戏全球流水TOP20:《原神》排名第三
- 《纸片马里奥RPG重置版》新预告 5月23日正式发售
- 蓄势待发了!开发商称对《寂静岭2RE》表现充满信心
- 梦剧院.1998-十年十美·十周年新曲+精丫乐意唱片】【WAV+CUE】
- 萧亚轩.2014-不解释亲吻【SONY】【WAV+CUE】
- 群星.2023-长风渡影视原声带【韶愔音乐】【FLAC分轨】
- 林慧萍1996-12-忘了我是女人[点将][WAV+CUE]
- 群星.2023-三体影视原声专辑【炎乐传媒】【FLAC分轨】
- 群星.2024-别对我动心影视原声带【千曜音乐】【FLAC分轨】
- 《明日方舟》联动中国电影资料馆 携手修复经典动画《铁扇公主》
- 《寂静岭2:重制版》开发商新作曝光:与T2合作开发的全新IP