MYSQL必知必会读书笔记 第十二和十三章 分组数据
2016-05-06 15:13
495 查看
1.group by 可以包含任意数目的列 2.group by 中每个列都必须是检索列或有效的表达式(但不能使聚集函数) 3.除聚集函数外,select语句中的每个列都必须在group by子句中出现 4.如果分组列有Null值,Null将作为一个分组返回 5.group by 子句必须出现在where子句之后, order by 之前 where 和 have 的区别: where在分组前过滤,having在分组后过滤 SELECT vend_id ,COUNT(*) AS num_prods FROM products GROUP BY vend_id; GROUP BY子句指示MySQL分组数据,然后对每个组而不是整个结果集进行聚集。 在使用GROUP BY子句之前,需要知道一些重要的规定: 1. GROUP BY 子句可以包含任意数目的列。这使得能对分组进行嵌套,为数据分组提供更细致的控制。 2. 如果GROUP BY子句中嵌套了分组,数据将最后规定的分组上进行汇总。换句话说,在建立分组时,指定的所有列都一起计算(所以不能从个别的列取回数据) 3. GROUP BY 子句中列出的每个列都必须是检索列或有效的表达式(但不能是聚集函数)。如果在SELECT 中使用表达式,必须在GROUP BY子句中指定相同的表达式。不能使用别名。 4.除聚集计算语句外,SELECT 语句中的每个列都必须在GROUP BY 子句中给出。 5.如果分组列中具有NULL 值,则将NULL作为一个分组返回 6.GROUP BY 子句必须出现在where子句之后。ORDER BY 子句之前。 注意:使用ROLLUP 使用WITH ROLLUP 关键字,可以得到每个分组以及每个分组汇总级别(针对每个分组)的值。 SELECT vend_id ,COUNT(*) AS num_prods FROM products GROUPS BY vend_id WITH ROLLUP; 二 :过滤分组 我们已经看到了WHERE 子句的作用,但是这个例子中WHERE 不能完成任务。因为WHERE过滤指定的行而不是分组。事实上WHERE 没有分组的概念。MYSQL中为此目的 提供了类似的语句,那就是HAVING子句。HAVING非常类似于WHERE。事实上,目前为止所有学过的所有类型的WHERE子句都可以用HAVING来替代。唯一的差别是WHERE过滤行 ,而HAVING过滤分组。 SELECT cust_id,COUNT(*) AS orders FROM orders GROUP BY cust_id HAVING COUNT(*)>=2; 注意:HAVING 与WHERE 的区别 WHERE 在数据分组前进行过滤,HAVING在数据分组后进行过滤。这是一个重要区别,WHERE排除的行不会出现在分组中。可能改变分组值,从而影响HAVING子句中基于这些值过滤掉分组。 为了更好的理解,请看下面一个例子,它列出具有2个以上,价格为10以上的产品的供应商。 SELECT vend_id,COUNT(*) AS num_prods FROM products where prod_price>=10 GROUP BY vend_id HAVING COUNT(*)>=2; 需要注意的是:在使用GROUP BY 子句时,应该也给出ORDER BY子句。这保证数据正确排序的唯一方法。 SELECT order_num,SUM(quantity*item_price) AS ordertotal FROM orderitems GROUP by order_num HAVING SUM(quantity* item_price)>=50 ORDER BY ordertotal;
相关文章推荐
- windows版mysql配置--my.ini
- mysql更改最大打開文件數
- Ubuntu下mysql的安装以及简单的命令操作
- MySQL 子查询 EXISTS 和 NOT EXISTS
- MYSQL show engine等实用 command
- /usr/bin/ld: cannot find -lmysqlclient
- mysqldb模块
- MySQL学习4:Windows 64位操作系统下使用MySQL
- ubuntu安装mysql
- mysql建表属性不能为关键字
- MySQL Connector ODBC 安装出现 “找不到指定的模块xxx”
- MySql UDF 调用外部程序和系统命令
- MySQL使用udf调用系统程序
- mysqldump导出多个数据库
- mysqldump参数详细说明(转)
- mysql数据库---批处理与大文本/图片类型
- mysql 函数
- Mysql导入sql文件乱码问题
- mysql 多表关联更新
- MySql数据库编码