|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
但我们知道,若使用statement,并没有上述需要的数据。试想binlog中记录了一句updatetsetf1=3whereid=3。怎么恢复呢?在先容GROUPBY和HAVING子句前,我们必须先讲讲sql言语中一种特别的函数:聚合函数,比方SUM,COUNT,MAX,AVG等。这些函数和别的函数的基本区分就是它们一样平常感化在多笔记录上。
SELECTSUM(population)FROMbbc
这里的SUM感化在一切前往纪录的population字段上,了局就是该查询只前往一个了局,即一切国度的总生齿数。
经由过程利用GROUPBY子句,可让SUM和COUNT这些函数对属于一组的数据起感化。当你指定GROUPBYregion时,属于统一个region(区域)的一组数据将只能前往一行值,也就是说,表中一切除region(区域)外的字段,只能经由过程SUM,COUNT等聚合函数运算后前往一个值。
HAVING子句可让我们选择成组后的各组数据,WHERE子句在聚合前先选择纪录.也就是说感化在GROUPBY子句和HAVING子句前。而HAVING子句在聚合后对组纪录举行选择。
让我们仍是经由过程详细的实例来了解GROUPBY和HAVING子句,还接纳第三节先容的bbc表。
SQL实例:
1、显现每一个区域的总生齿数和总面积:
以下为援用的内容:
SELECTregion,SUM(population),SUM(area)
FROMbbc
GROUPBYregion
先以region把前往纪录分红多个组,这就是GROUPBY的字面寄义。分完组后,然后用聚合函数对每组中的分歧字段(一或多笔记录)作运算。
2、显现每一个区域的总生齿数和总面积.仅显现那些面积凌驾1000000的区域。
以下为援用的内容:
SELECTregion,SUM(population),SUM(area)
FROMbbc
GROUPBYregion
HAVINGSUM(area)>1000000
在这里,我们不克不及用where来选择凌驾1000000的区域,由于表中不存在如许一笔记录。
相反,HAVING子句可让我们选择成组后的各组数据。
因此我们的保存数据方法就是:在删除的动作开始之前,把表数据备份起来,然后留一个空表,在空表上执行“删除”操作。 |
|