SQL---DML---GROUP BY与ORDER BY比较
2011-09-14 22:30
561 查看
GROUP BY与ORDER BY,一个是分组,一个是排序,这是我自己的第一反应。
ORDER BY 与GROUP BY
第一项比较重要,经常发现用GROUP BY分组的数据确实是以分组顺序输出的,但不总是这样,而且用户可能会要求以不同的顺序排序。
一般在使用GROUP BY子句时,应该也给出ORDER BY子句,这是保证数据正确排序的唯一方法。千万不要仅依赖GROUP BY排序数据。
例:
view plainSELECT order_num,COUNT(*) AS items
FROM OrderItems
GROUP BY order_num
HAVING COUNT(*)>=3
ORDER BY items,order_num;
ORDER BY | GROUP BY |
排序产生的输出 | 分组行。但输出可能不是分组的顺序 |
任意列都可以使用(甚至非选择的列也可以使用) | 只可能使用选择列或表达式列,而且必须使用每个选择列表达式 |
不一定需要 | 如果与聚集函数一起使用列(或表达式),则必须使用 |
一般在使用GROUP BY子句时,应该也给出ORDER BY子句,这是保证数据正确排序的唯一方法。千万不要仅依赖GROUP BY排序数据。
例:
view plainSELECT order_num,COUNT(*) AS items
FROM OrderItems
GROUP BY order_num
HAVING COUNT(*)>=3
ORDER BY items,order_num;
相关文章推荐
- SQL---DML---GROUP BY与ORDER BY比较
- SQL中group by分组查询的内容(包含to_char和order by)
- sql语句中where、group by、having、order by 是否可以使用别名
- SQL语句中的group by 和 order by
- sql中 order by 和 group by的区别
- SQL中order by 、group by 、having的用法区别
- sql中Distinct、Group by、having、order by使用注意事项
- sql中 order by 和 group by的区别
- LINQ to SQL 实现 GROUP BY、聚合、ORDER BY
- SQL中order by 、group by 、having的用法区别
- SQL语句之order by 、group by、having、where
- 用到 count; group by ; order by ;having 的一个SQL语句
- SQL 语句:order by 和group by 语句的注意点:
- 当一个SQL语句同时出现了where,group by,having,order by的时候,执行顺序和编写顺序
- mysql的group by、order by和having、where比较
- SQL 语句:order by 和group by 语句的注意点:
- sql server where、group by、order by 执行顺序
- sql语句中group by 与order by的区别
- T-sql语句,group by 加 order by的使用方法
- SQL中灵活运用Group by 和 Order by