选择列表中的列无效,因为该列没有包含在聚合函数或 GROUP BY 子
发布时间:2020-12-14 05:06:06 所属栏目:百科 来源:网络整理
导读:解决方案:指定 GROUP BY 时,选择列表中任何非聚合表达式内的每个属性名都应包含在GROUP BY列表中,或者GROUP BY表达式必须与选择列表表达式完全匹配。 错误用法: select top 1000 订单ID,客户ID,订单号,实付金额,主订单ID FROM [TRA].[dbo].[订单] group
解决方案:指定 GROUP BY 时,选择列表中任何非聚合表达式内的每个属性名都应包含在GROUP BY列表中,或者GROUP BY表达式必须与选择列表表达式完全匹配。 错误用法: select top 1000 订单ID,客户ID,订单号,实付金额,主订单ID FROM [TRA].[dbo].[订单] 报错:? ? ? ? 正确用法1: select top 1000 订单ID,min(客户ID),min(订单号),min(实付金额),min(主订单ID) FROM [TRA].[dbo].[订单] 正确用法2: select top 1000 订单ID,主订单ID FROM [TRA].[dbo].[订单] group by 订单ID,主订单ID order by 订单ID ?min最小值:在没用group分组时,此刻整张表为一个组,min返回的是这一列中数据最小的数据, ? ? ? ? ? ? ? ? ? ? ?使用group分组时,min返回的是所在组的最小数据. ? 使用Group By子句的时候,一定要记住下面的一些规则:(1)不能Group By非标量基元类型的列,如不能Group By text,image或bit类型的列(2)Select指定的每一列都应该出现在Group By子句中,除非对这一列使用了聚合函数;(3)不能Group By在表中不存在的列;(4)进行分组前可以使用Where子句消除不满足条件的行;(5)使用Group By子句返回的组没有特定的顺序,可以使用Order By子句指定次序。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |