发布网友 发布时间:2022-04-28 23:38
共4个回答
热心网友 时间:2022-04-09 05:07
我甚是理解你 我开始也很不明白追答所以说group by的条件越多 分组越细 越没有意义
给你一个前辈给我讲时的列子你再理解一下:
A B C D 数量
001 B1 C1 D1 10
001 B2 C2 D2 20
002 B3 C3 D3 30
002 B3 C3 D4 40
GROUP BY条件 分组结果求SUM(数量)
A 2行 30
70
A,B 3行 10
20
70
A,B,C 3行 10
20
70
A,B,C,D 4行 10
20
30
40
我觉得这个例子应该很明确分组概念了 你可以理解一下
如果还不明白可以继续探讨
热心网友 时间:2022-04-09 06:25
在Oracle中,表中是以非指定顺序存储行数据记录的,它不管行插入数据库的顺序如何。要按列以升序或降序查询行记录,必须明确指示Oracle数据库要如何去排序。
例如,您可能希望按名称的字母顺序列出所有客户,或者按照从最低到最高信用限额的顺序显示所有客户。
要对数据进行排序,我们可以将ORDER BY子句添加到SELECT语句中,参考以下语法:
要按列排序结果集,可以在ORDER BY子句之后列出该列。
按照列名是一个排序顺序,可以是:
ASC表示按升序排序
DESC表示按降序排序
默认情况下,无论是否指定ASC,ORDER BY子句都按升序对行进行排序。如果要按降序对行进行排序,请明确使用DESC。
NULLS FIRST在非NULL值之前放置NULL值,NULLS LAST在非NULL值之后放置NULL值。
ORDER BY子句可以按多列对数据进行排序,每列可能有不同的排序顺序。
请注意,ORDER BY子句总是SELECT语句中的最后一个子句。
GROUP BY 是一个聚合子句,相当于把查询出的结果按某种方式分组。
教程来源:树懒学堂_一站式数据知识平台_Oracle Order By子句
热心网友 时间:2022-04-09 08:00
order by 顾名思义,就是排序的意思 order by 某列(column) 就是你查看的结果是根据某列的升降序显示的。追答你可以吧查询结果贴出来一下,结果是 以上2个分组+avg()升序来显示。
热心网友 时间:2022-04-09 09:51
一个排序 一个分组 怎么不明白呀 不是一个意义呀