首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

GROUP BY 后 SELECT 列的限制:which is not functionally dependent on columns in GROUP BY clause

GROUP BY 后 SELECT 列的限制 标准 SQL 规定,在对表进行聚合查询的时候,只能在 SELECT 子句中写下面 3 种内容:通过 GROUP BY 子句指定的聚合键、聚合函数(SUM 、...SQL 模式主要分两类:语法支持类和数据检查类,常用的如下 语法支持类    ONLY_FULL_GROUP_BY 对于 GROUP BY 聚合操作,如果在 SELECT 中的列、HAVING 或者...ORDER BY 子句的列,没有在GROUP BY中出现,那么这个SQL是不合法的 ANSI_QUOTES 启用 ANSI_QUOTES 后,不能用双引号来引用字符串,因为它被解释为识别符,作用与...是有自己的默认模式的;版本不同,默认模式也不同 -- 查看 MySQL 版本 SELECT VERSION(); -- 查看 sql_mode SELECT @@sql_mode; -- 设置宽松模式...SELECT 子句中不能直接引用原表中的列的原因;   3、一般来说,单元素集合的属性和其唯一元素的属性是一样的。

3.2K50

解决SQL中的“Expression #1 of SELECT list is not in GROUP BY clause“错误

这个错误主要是由于SELECT列表中的列没有在GROUP BY子句中进行分组。本文将详细讲解该错误的成因,并提供有效的解决方案。 正文内容(详细介绍) 1....错误的成因 在SQL查询中,GROUP BY子句用于将结果集按一个或多个列进行分组。...而SELECT列表中的每一列都必须是一个聚合函数或出现在GROUP BY子句中,否则SQL引擎无法确定如何对这些列进行分组,从而导致错误。 2....ONLY_FULL_GROUP_BY:这是MySQL中的一个模式,它严格要求SELECT列表中的每一列都必须在GROUP BY子句中或是聚合函数的一部分。...A: ONLY_FULL_GROUP_BY模式严格要求SELECT列表中的每一列都必须在GROUP BY子句中或是聚合函数的一部分,否则会报错。

14710
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    SQL中的聚合函数介绍

    聚合函数经常与 SELECT 语句的 GROUP BY 子句一同使用。 所有聚合函数都具有确定性。任何时候用一组给定的输入值调用它们时,都返回相同的值。 标量函数:只能对单个的数字或值进行计算。...select avg(score) from Scores ---平均成绩 select avg(salary) from Company --平均工资 注意: 若某行的score值为null时,计算平均值时会忽略带有...select min(Score) from Scores select min(salary) from Company 聚合函数怎么正确的使用?...数据类型详见: SQL Server 数据类型的详细介绍及应用实例1 SQL Server 数据类型的详细介绍及应用实例2 SQL Server 数据类型的详细介绍及应用实例3 例如: select...count_big(prd_no) from sales 7、 grouping()产生一个附加的列。

    2.2K10

    SQL基础-->分组与分组函数

    带有expr参数的函数的数据类型可以为CHAR,VARCHAR2,NUMBER,DATE. 所有分组函数都忽略空值。...: SELECT 中出现的列,如果未出现在分组函数中,则GROUP BY子句必须包含这些列 WHERE 子句可以某些行在分组之前排除在外 不能在GROUP BY 中使用列别名 默认情况下GROUP...BY列表中的列按升序排列 GROUP BY 的列可以不出现在分组中 七、分组过滤: 使用having子句 having使用的情况: 行已经被分组 使用了组函数 满足having子句中条件的分组将被显示...1037.5 SALESMAN 1400 PRESIDENT 5000 MANAGER 2758.33333 ANALYST 3000 --GROUP BY 的列可以不出现在分组中 SQL...2758.33333 1400 1037.5 --错误的用法,SELECT 中的有些列没有在GROUP BY子句中出现 SQL> select job,avg(sal) from emp;

    3.3K20

    神奇的 SQL 之层级 → 为什么 GROUP BY 之后不能直接引用原表中的列

    GROUP BY 后 SELECT 列的限制   标准 SQL 规定,在对表进行聚合查询的时候,只能在 SELECT 子句中写下面 3 种内容:通过 GROUP BY 子句指定的聚合键、聚合函数(SUM...=only_full_group_by   提示信息:SELECT 列表中的第二个表达式(cname)不在 GROUP BY 的子句中,同时它也不是聚合函数;这与 sql 模式:ONLY_FULL_GROUP_BY...SQL 模式主要分两类:语法支持类和数据检查类,常用的如下   语法支持类         ONLY_FULL_GROUP_BY       对于 GROUP BY 聚合操作,如果在 SELECT 中的列...,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION     而第一个:ONLY_FULL_GROUP_BY 就会约束:当我们进行聚合查询的时候,SELECT 的列不能直接包含非...GROUP BY 子句中的列。

    2.2K20

    Oracle Database 21c 中的 ANY_VALUE 聚合函数

    由于我们并不关心 GROUP BY 中是否包含 DNAME 列,但是受制于语法必须得这样做,同时在 GROUP BY 中添加额外的列也会造成不必要的开销,为了避免这个问题,大家可能会使用 MIN 或者...> 这种写法使得我们可以从 GROUP BY 中拿掉 DNAME 列,但是新增了 MIN 或者 MAX 函数造成了新的开销。...> 所以现在我们可以减少 GROUP BY 中附加列的开销,而不必添加 MIN 或 MAX 函数的开销。...数据量小的情况下,我们可能无法观测到性能的改进,但随着数据量的增加,GROUP BY 或者使用 MIN 和 MAX 函数的开销必然超过 ANY_VALUE。...由于 MIN 和 MAX 函数是有确定意义的,如果代码编写者当时仅出于从 GROUP BY 中排除非必要列,非代码编写者读代码时可能对于该写法无法理解其用意,但是 ANY_VALUE 函数是非确定性的,

    59210

    SQL语言

    ①基础查询在SQL中,通过SELECT关键字开头的SQL语句进行数据的查询。基础语法:含义:从(FROM)表中,选择(SELECT)某些列进行展示。...id, name FROM student;#查询全部列SELECT id, name, age FROM student;#查询全部列(快捷写法)SELECT * FROM student;查询也可以带有指定条件...分组(GROUP BY):使用 GROUP BY 语句对结果集中的数据进行分组,通常基于一个或多个列聚合函数:在分组后,可以使用聚合函数(如 COUNT、SUM、AVG、MAX、MIN 等)计算每个组的统计数据聚合列...BY gender;#按性别分组,统计最大最小年龄SELEcT gender, MAX(age),MIN(age) FROM student GROUP BY gender;【注意】在 SELECT...接着,对结果进行分组与聚合(GROUP BY),再提取所需的列(SELECT)。随后,对结果进行排序(ORDER BY),最后限制返回的记录数量或进行分页(LIMIT)。

    6211

    MySQL学习9_DQL之聚合与分组

    聚合函数 在实际中我们可能只是需要汇总数据而不是将它们检索出来,SQL提供了专门的函数来使用。...后面跟的列名最好不是原表中已经存在的列名,避免歧义 select count(*) as num_items, -- 同时使用多个聚合函数 min(prod_price) as price_min,...分组中使用最多的是group by和having group by 看一个group by的栗子 select vend_id, coutn(*) as num_prods -- 指定两个列 from...Products group by vend_id; -- 指定分组的字段:对每个vend_id进行计算 规定: group by中可以包含任意数目的列,可以进行嵌套 group by子句中列出的每一列都是检索列或者有效的表达式...group by在where之后,order by之前 能够通过相对位置指定列,group by 2, 1 如果分组列中带有NULL的行,将它们作为一个组返回 having 除了能够group by

    1.7K10

    SQL必知必会总结2-第8到13章

    本文是《SQL必知必会》一书的精华总结,帮助读者快速入门SQL或者MySQL,主要内容包含: 数据库基础知识 库表的相关操作 检索数据的方法 … 本文中介绍的第8到13章,前面的章节请看SQL必知必会总结...汇总数据 聚集函数 聚集函数指的是对某些行运行的一个函数,并且返回一个值,常用的聚集函数有: 函数 作用 AVG() 返回列的平均值 COUNT() 返回列的函数 MAX() 返回列的最大值 MIN()...:如果指定列名,则COUNT()函数会忽略指定列的值为空的行,但是如果COUNT()函数使用的是星号,则不会忽略 3、MAX()/MIN()函数 返回指定列中的最大值或者最小值 SELECT MAX...,可以对分组进行嵌套 GROUP BY子句中列出的每一列都是检索列或者有效的表达式(但是不能是聚集函数) 如果在SELECT中使用表达式,则必须在GROUP BY子句中使用相同的表达式,而不是使用别名...除了聚集函数外,SELECT语句中的每列都必须在GROUP BY子句中列出 如果分组中包含具有NULL的行,则NULL将作为一个分组返回;如果列中出现多个NULL,它们将分成一个组 GROUP BY子句必须在

    2.3K21

    MySQL单表&约束&事务

    ; SELECT 聚合函数(字段名) FROM 表名; 聚合函数 作用 count(字段) 统计指定列不为NULL的记录行数 sum(字段) 计算指定列的数值和 max(字段) 计算指定列的最大值 min...SQL 得到的总条数不准确,因为count函数忽略了空值 -- 所以使用时注意不要使用带有null的列进行统计 SELECT COUNT(dept_name) FROM emp; #2 查看员工总薪水...、最高薪水、最小薪水、薪水的平均值 -- sum函数求和, max函数求最大, min函数求最小, avg函数求平均值 SELECT SUM(salary) AS '总薪水', MAX(salary)...GROUP BY 语句,对查询的信息进行分组,相同数据作为一组 SELECT 分组字段/聚合函数 FROM 表名 GROUP BY 分组字段 [HAVING 条件]; -- 按照性别进行分组操作 SELECT...: 主键约束 唯一且不能够为空 唯一约束,唯一 但是可以为空 一个表中只能有一个主键 , 但是可以有多个唯一约束 默认值 默认值约束 用来指定某列的默认值 -- 创建带有默认值的表 CREATE TABLE

    1.2K30

    MySQL数据库(三)

    一、聚合查询 (一)聚合函数 函数与括号之间不能有空格 1、count  查询到的数据的数量,null不会计入结果 select count(列名) from 表名; 同时,也可以使用全列查询: select...,不是数字没有意义,不能进行全列查询 select avg(列名) from 表名; 4、max 查询到的数据的最大值,不是数字没有意义,不能进行全列查询 select max(列名) from 表名;...5、min 查询到的数据的最小值,不是数字没有意义,不能进行全列查询 select min(列名) from 表名; 二、分组查询 (一)group by 指定一个列,把列里面相同的值分为一组进行查询...列如:  同时,select 指定的列,要么是带有聚合函数的,要么是group by 指定的列,不能是一个非聚合非group by 的列,否则查询结果无意义。...也可以写成: insert into 表1 select *from 表2; 结语 SQL查询中各个关键字的执行先后顺序: from > on > join > where > group by > with

    22530

    .NET6 开源之JSON 2 SQL (JORM框架)

    、查询返回备注 4、可以配置化 5、支持丰富的SQL语法 6、数据验证 7、JSON作为数据库中间语言支持多种数据库 为什么要开发JORM 我们都知道 ORM用起来非常舒服,都是强类型,但是他的缺点很显...1、对动态操作支持比较弱 , 很多功能都要各自封装,很难支持到函数级别 2、不能支持列级别的过滤,比如A用户显示2列,B用户显示3列,像这种很难处理 3、无法动态构造,这就导致了无法很好地用在 工作流...},"Date"] ] } 代码: jsonToSqlClient.Queryable(json).ToSql() //Sql //SELECT MIN(`id`) AS `id` , NOW() AS...`Date` FROM `Order` 2.2 带有条件的查询 { "Table":"order", Where:[ "name","=", "{string}:xxx" ],...(json).ToSql() //Sql //SELECT MIN(`id`) AS `id` , NOW() AS `Date` FROM `Order` WHERE `name` = @p0

    29710

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券