• 选择列表中的列无效,因为该列没有包含在聚合函数或 GROUP BY 子句中


    解决方案:指定 GROUP BY 时,选择列表中任何非聚合表达式内的每个属性名都应包含在GROUP BY列表中,或者GROUP BY表达式必须与选择列表表达式完全匹配。

    错误用法:

    select top 1000 订单ID,客户ID,订单号,实付金额,主订单ID  FROM [TRA].[dbo].[订单] 
    group by 订单ID
    order by 订单ID

    报错:     

    正确用法1:

    select top 1000 订单ID,min(客户ID),min(订单号),min(实付金额),min(主订单ID)  FROM [TRA].[dbo].[订单]  
    group by 订单ID
    order by 订单ID

    正确用法2:

        select top 1000 订单ID,客户ID,订单号,实付金额,主订单ID  FROM [TRA].[dbo].[订单]  
        group by 订单ID,客户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子句指定次序。

  • 相关阅读:
    venv(virtual environment)的使用
    Pytest 失败重运行机制
    Python 中方法和函数的区别
    手机移动端WEB资源整合
    Sass学习日志
    1、vue基础使用复习
    vscode配置笔记
    vue兼容IE浏览器、对低版本IE下的友好提示
    关闭eslint校验
    vue实现吸顶的效果
  • 原文地址:https://www.cnblogs.com/likui-bookHouse/p/9577795.html
Copyright © 2020-2023  润新知