关于mysql中order by与group by的问题

问题描述

关于mysql中order by与group by的问题
select * from (select * from t2 order by gidcol2 desc) as t group by gid

这条sql语句执行完之后,为什么gid的排序是增序的???

解决方案

(select * from t2 order by gid desccol2 desc)

给gid加个desc

解决方案二:
语句先执行select * from t2 order by gidcol2 desc 对gid的排序,然后在分组的

解决方案三:
select * from t2 order by gidcol2 desc执行过后取结果作为t
select * from t group by gid
这样每组都会取第一条显示出来

解决方案四:
虽然你子查询中是降序的,但你外面没有指定,所以缺省还是按升序排得。所以你需要显示指定order by xx desc

解决方案五:

 select * from (select * from t2 order by gidcol2 desc) as t group by gid 子句这么order by意义不大,放到最外层吧 select * from (select * from t2 ) as t  group by gid order by gid desc  倒序写desc

解决方案六:
因为默认的就是升序。应该在最外部加上这句话order by gidcol2 desc。
select * from (select * from t2) as t group by gid order by gidcol2 desc

解决方案七:
select * from t2 group by gid order by col2 desc

解决方案八:
select * from (select * from t2 order by gidcol2 desc) as t group by** t.gid**

解决方案九:
谢谢诸位了,问题已经解决了。

解决方案十:
对,到最后面价格desc 的

时间: 2024-11-17 01:12:25

关于mysql中order by与group by的问题的相关文章

mysql中order by与group by的区别

以下是对mysql中order by与group by的区别进行了详细的分析介绍,需要的朋友可以过来参考下   order by 从英文里理解就是行的排序方式,默认的为升序. order by 后面必须列出排序的字段名,可以是多个字段名.      group by 从英文里理解就是分组.必须有"聚合函数"来配合才能使用,使用时至少需要一个分组标志字段.  什么是"聚合函数"?  像sum().count().avg()等都是"聚合函数"  使用

深入解析mysql中order by与group by的顺序问题_Mysql

mysql 中order by 与group by的顺序是:selectfromwheregroup byorder by注意:group by 比order by先执行,order by不会对group by 内部进行排序,如果group by后只有一条记录,那么order by 将无效.要查出group by中最大的或最小的某一字段使用 max或min函数.例:select sum(click_num) as totalnum,max(update_time) as update_time,

Mysql中order by、group by、having的区别深入分析_Mysql

order by 从英文里理解就是行的排序方式,默认的为升序. order by 后面必须列出排序的字段名,可以是多个字段名.  group by 从英文里理解就是分组.必须有"聚合函数"来配合才能使用,使用时至少需要一个分组标志字段. 什么是"聚合函数"? 像sum().count().avg()等都是"聚合函数" 使用group by 的目的就是要将数据分类汇总. 一般如: select 单位名称,count(职工id),sum(职工工资)

mysql中order by与group by的区别_Mysql

order by 从英文里理解就是行的排序方式,默认的为升序. order by 后面必须列出排序的字段名,可以是多个字段名.      group by 从英文里理解就是分组.必须有"聚合函数"来配合才能使用,使用时至少需要一个分组标志字段.  什么是"聚合函数"?  像sum().count().avg()等都是"聚合函数"  使用group by 的目的就是要将数据分类汇总.

sql中 order by 和 group by的区别_MsSql

order by 从英文里理解就是行的排序方式,默认的为升序. order by 后面必须列出排序的字段名,可以是多个字段名. group by 从英文里理解就是分组.必须有"聚合函数"来配合才能使用,使用时至少需要一个分组标志字段. 什么是"聚合函数"?           像sum().count().avg()等都是"聚合函数"          使用group by 的目的就是要将数据分类汇总. 一般如: select 单位名称,coun

sql中 order by 和 group by的区别

order by 从英文里理解就是行的排序方式,默认的为升序. order by 后面必须列出排序的字段名,可以是多个字段名. group by 从英文里理解就是分组.必须有"聚合函数"来配合才能使用,使用时至少需要一个分组标志字段. 什么是"聚合函数"? 像sum().count().avg()等都是"聚合函数" 使用group by 的目的就是要将数据分类汇总. 一般如: select 单位名称,count(职工id),sum(职工工资) f

Mysql中order by语句的优化详解

在某些情况中,MySQL可以使用一个索引来满足ORDER BY子句,而不需要额外的排序.where条件和order by使用相同的索引,并且order by的顺序和索引顺序相同,并且order by的字段都是升序或者都是降序. 一.建议使用一个索引来满足Order By子句. 在条件允许的情况下,笔者建议最好使用一个索引来满足Order By子句.如此的话,就可以避免额外的排序工作.这里笔者需要强调的一点是及时Order By子句不确切匹配索引,但是只要Where子句中所有未使用的索引部分和所有

mysql中order by 语句的用法 索引优化

MySQL Order By keyword是用来给记录中的数据进行分类的. MySQL Order By Keyword根据关键词分类 ORDER BY keyword是用来给记录中的数据进行分类的. MySQL Order By语法  代码如下 复制代码 SELECT column_name(s) FROM table_name ORDER BY column_name 注意:SQL语句是"字母大小写不敏感"的语句(它不区分字母的大小写),即:"ORDER BY"

mysql中order by 和limit一起使用不当会导致效率极慢的4种优化方法

今天从慢查询发现一条语句查询时间达6秒.结果只查出一条记录. 原语句如下 SELECT biz_order_id, buyer_id, buyer_nick, gmt_create, gmt_modified, attributeCc, seller_id FROM trade.biz_order WHERE shop_id=20484 AND STATUS=4 AND gmt_create >= '2017-10-30 16:34:42' AND order_type = 6 ORDER BY