首页
学习
活动
专区
工具
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 或者...启用 NO_ENGINE_SUBSTITUTION 时,那么直接抛出错误;不设置此值时,CREATE用默认的存储引擎替代,ATLER不进行更改,并抛出一个 warning STRICT_TRANS_TABLES...0,产生一个warning; 2、Out Of Range,变成插入最大边界值; 3、当要插入的新行中,不包含其定义中没有显式DEFAULT子句的非NULL列的值时,该列缺少值; 解决步骤 MySQL

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

    select count(*)、count(1)、count(主键列)和count(包含空值的列)有何区别?

    下班路上看见网上有人问一个问题: oracle 10g以后count(*)和count(非空列)性能方面有什么区别?...首先,准备测试数据,11g库表bisal的id1列是主键(确保id1列为非空),id2列包含空值, ?...前三个均为表数据总量,第四个SQL结果是99999,仅包含非空记录数据量,说明若使用count(允许空值的列),则统计的是非空记录的总数,空值记录不会统计,这可能和业务上的用意不同。...其实这无论id2是否包含空值,使用count(id2)均会使用全表扫描,因此即使语义上使用count(id2)和前三个SQL一致,这种执行计划的效率也是最低的,这张测试表的字段设置和数据量不很夸张,因此不很明显...总结: 11g下,通过实验结论,说明了count()、count(1)和count(主键索引字段)其实都是执行的count(),而且会选择索引的FFS扫描方式,count(包含空值的列)这种方式一方面会使用全表扫描

    3.4K30

    Oracle列转行函数LISTAGG() WITHIN GROUP ()的使用方法

    大家好,又见面了,我是你们的朋友全栈君。...前言:最近在写一些比较复杂的SQL,是一些统计分析类的,动不动就三四百行,也是首次写那么长的SQL,有用到一些奇形怪状的SQL函数,在这里结合网上的例子做一些笔记,以后用到不记得用法可以翻出来看!...1.基础用法:LISTAGG(XXX,XXX) WITHIN GROUP( ORDER BY XXX),就像聚合函数一样,通过Group by语句,把每个Group的一个字段,拼接起来 LISTAGG(...(ORDER BY CITY) AS CITIES FROM TEMP GROUP BY NATION 运行结果: (2)示例代码: 查询部门为20的员工列表:SELECT t.DEPTNO...如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

    4.8K10

    包含列的索引:SQL Server索引进阶 Level 5

    在这个级别中,我们检查选项以将其他列添加到非聚集索引(称为包含列)。 在检查书签操作的级别6中,我们将看到SQL Server可能会单方面向您的索引添加一些列。...包括列 在非聚集索引中但不属于索引键的列称为包含列。 这些列不是键的一部分,因此不影响索引中条目的顺序。 而且,正如我们将会看到的那样,它们比键列造成的开销更少。...创建非聚集索引时,我们指定了与键列分开的包含列; 如清单5.1所示。...确定索引列是否是索引键的一部分,或只是包含的列,不是您将要做的最重要的索引决定。也就是说,频繁出现在SELECT列表中但不在查询的WHERE子句中的列最好放在索引的包含列部分。...为了说明在索引中包含列的潜在好处,我们将查看两个针对SalesOrderDetailtable的查询,每个查询我们将执行三次,如下所示: 运行1:没有非聚集索引 运行2:使用不包含列的非聚簇索引(只有两个关键列

    2.4K20

    为什么 GROUP BY 之后不能直接引用原表中的列

    GROUP BY 后 SELECT 列的限制   标准 SQL 规定,在对表进行聚合查询的时候,只能在 SELECT 子句中写下面 3 种内容:通过 GROUP BY 子句指定的聚合键、聚合函数(SUM...为什么 GROUP BY 之后不能直接引用原表(不在 GROUP BY 子句)中的列 ? 莫急,我们慢慢往下看。...0,产生一个warning;       2、Out Of Range,变成插入最大边界值;       3、当要插入的新行中,不包含其定义中没有显式DEFAULT子句的非NULL列的值时,该列缺少值...SELECT @@sql_mode;      我们可以看到,5.7.21 的默认模式包含: ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE...就会约束:当我们进行聚合查询的时候,SELECT 的列不能直接包含非 GROUP BY 子句中的列。

    1.7K10

    Python:说说字典和散列表,散列冲突的解决原理

    这就要求键(key)必须是可散列的。 一个可散列的对象必须满足以下条件: 支持 hash() 函数,并且通过 __hash__() 方法所得到的散列值是不变的。...于是就会发生下面的情况:dict([key1, value1], [key2, value2]) 和 dict([key2, value2], [key1, value1]) 两个字典,在进行比较的时候是相等的...,但如果 key1 和 key2 散列冲突,则这两个键在字典里的顺序是不一样的。...无论何时,往 dict 里添加新的键,python 解析器都可能做出为字典扩容的决定。扩容导致的结果就是要新建一个更大的散列表,并把字典里已有的元素添加到新的散列表里。...这个过程中可能发生新的散列冲突,导致新散列表中键的次序变化。如果在迭代一个字典的同时往里面添加新的键,会发生什么?不凑巧扩容了,不凑巧键的次序变了,然后就 orz 了。

    2K30

    forestploter: 分组创建具有置信区间的多列森林图

    下面是因INFORnotes的分享 与其他绘制森林图的包相比,forestploter将森林图视为表格,元素按行和列对齐。可以调整森林图中显示的内容和方式,并且可以分组多列显示置信区间。...森林图的布局由所提供的数据集决定。 基本的森林图 森林图中的文本 数据的列名将绘制为表头,数据中的内容将显示在森林图中。应提供一个或多个不带任何内容的空白列以绘制置信区间(CI)。...") # Print plot plot(p) 更改主题背景 增加汇总列并修改图形参数 dt_tmp <- rbind(dt[-1, ], dt[1, ]) dt_tmp[nrow(dt_tmp)...add_text该函数可用于向某些行/列添加文本。 insert_text该函数可用于在某一行之前或之后插入行并添加文本。...如果提供的est、lower和upper的数目大于绘制CI的列号,则est、lower和upper将被重用。如下例所示,est_gp1和est_gp2将画在第3列和第5列中。

    9K32

    Excel公式练习32: 将包含空单元格的多行多列单元格区域转换成单独的列并去掉空单元格

    本次的练习是:如下图1所示,单元格区域A1:D6中是一系列数据,其中包含空单元格,现在要将它们放置到一列中,并删除空单元格,如图中所示的单元格区域G1:G13,如何使用公式实现? ?...这个结果传递给INDIRECT函数: INDIRECT(“R1C00004”,0) 结果将取出第1行第4列中的值,即单元格D4中的值。 为什么选用10^5,并且使用R0C00000作为格式字符串呢?...使用足够大的数值,主要是为了考虑行和列扩展后能够准确地取出相应行列所在单元格的数据。 注意到,在TEXT函数中,先填充C之后的五个零,剩下的在填充R之后的部分。...TEXT(SMALL(IF(rngData"",10^5*ROW(rngData)+COLUMN(rngData)),ROWS($1:1)),"R0C00000"),0),"") 这个公式不需要辅助列。...这个公式的缺点是,当下拉很多行时,如果有许多行都为空,则仍会进行很多的计算,占有资源,不会像前面给出的公式,第一个IF判断为大于非空单元格值后,直接输入空值。有兴趣的朋友可以仔细研究。

    2.4K10

    按照A列进行分组并计算出B列每个分组的平均值,然后对B列内的每个元素减去分组平均值

    一、前言 前几天在Python星耀交流群有个叫【在下不才】的粉丝问了一个Pandas的问题,按照A列进行分组并计算出B列每个分组的平均值,然后对B列内的每个元素减去分组平均值,这里拿出来给大家分享下,一起学习...888] df = pd.DataFrame({'lv': lv, 'num': num}) def demean(arr): return arr - arr.mean() # 按照"lv"列进行分组并计算出..."num"列每个分组的平均值,然后"num"列内的每个元素减去分组平均值 df["juncha"] = df.groupby("lv")["num"].transform(demean) print(df...(输入是num列,输出也是一列),代码如下: import pandas as pd lv = [1, 2, 2, 3, 3, 4, 2, 3, 3, 3, 3] num = [122, 111, 222...这篇文章主要分享了Pandas处理相关知识,基于粉丝提出的按照A列进行分组并计算出B列每个分组的平均值,然后对B列内的每个元素减去分组平均值的问题,给出了3个行之有效的方法,帮助粉丝顺利解决了问题。

    3K20

    Pandas数据处理——通过value_counts提取某一列出现次数最高的元素

    这个图片的来自于AI生成,我起名叫做【云曦】,根据很多的图片进行学习后生成的  Pandas数据处理——渐进式学习——通过value_counts提取某一列出现次数最高的元素 ---- 目录 Pandas...数据处理——渐进式学习——通过value_counts提取某一列出现次数最高的元素 前言 环境 基础函数的使用 value_counts函数 具体示例 参数normalize=True·百分比显示 参数...AI大佬的文章中发现都有这个Pandas文章,每个人的写法都不同,但是都是适合自己理解的方案,我是用于教学的,故而我相信我的文章更适合新晋的程序员们学习,期望能节约大家的事件从而更好的将精力放到真正去实现某种功能上去...本专栏会更很多,只要我测试出新的用法就会添加,持续更新迭代,可以当做【Pandas字典】来使用,期待您的三连支持与帮助。...df = df['name'].value_counts(ascending=True) print(df) 效果:  总结 其实我们测试的过程中就能体会到这个函数的好用之处,直接就能出排序的结果,

    1.4K30

    Excel公式练习33: 将包含空单元格的多行多列单元格区域转换成单独的列并去掉空单元格(续)

    本次的练习是:这个练习题与本系列上篇文章的练习题相同,如下图1所示,不同的是,上篇文章中将单元格区域A1:D6中的数据(其中包含空单元格)转换到单独的列(如图中所示的单元格区域G1:G13)中时,是以行的方式进行的...,即先放置第1行中的数据、再放置第2行……依此类推。...这里,需要以列的方式进行,即先放置第1列中的数据、再放置第2列中的数据……依此类推,最终结果如图中所示的单元格区域H1:H13,如何使用公式实现? ? 图1 先不看答案,自已动手试一试。..."),{8,2},5) 应该获取单元格C2中的值,即数据区域的第2行第3列。...相关参考 Excel公式练习32:将包含空单元格的多行多列单元格区域转换成单独的列并去掉空单元格 Excel公式练习4:将矩形数据区域转换成一行或者一列

    2.3K10

    wm_concat()和group_concat()合并同列变成一行的用法以及和concat()合并不同列的区别

    原标题:oracle的wm_concat()和mysql的group_concat()合并同列变成一行的用法以及和concat()合并不同列的区别 前言 标题几乎已经说的很清楚了,在oracle中,concat...()函数和 “ || ” 这个的作用是一样的,是将不同列拼接在一起;那么wm_concat()是将同属于一个组的(group by)同一个字段拼接在一起变成一行。...mysql是一样的,只不过mysql用的是group_concat()这个函数,用法是一样的,这里就不过多介绍了。...wm_concat()这个个函数的介绍,我觉得都介绍的不是很完美,他们都是简单的说 这个是合并列的函数,但是我总结的概括为:把同组的同列字段合并变为一行(会自动以逗号分隔)。...mysql是一样的用法,把wm_concat 换成 group_concat()就可以啦,具体可以参考这篇文章的使用:浅析MySQL中concat以及group_concat的使用 不知道大家学会这个wm_concat

    8.9K50

    python读取txt中的一列称为_python读取txt文件并取其某一列数据的示例

    python读取txt文件并取其某一列数据的示例 菜鸟笔记 首先读取的txt文件如下: AAAAF110 0003E818 0003E1FC 0003E770 0003FFFC 90 AAAAF110...: print(i) 输出结果为: [‘0003E1FC’] [‘0003E208’] [‘0003E204’] [‘0003E208’] [‘0003E1FC’] 以上这篇python读取txt文件并取其某一列数据的示例就是小编分享给大家的全部内容了...,改变了列的类型 第三:查看列类型 print(data.dtypes) 第四:方法一 本文实例讲述了python读取json文件并将数据插入到mongodb的方法.分享给大家供大家参考.具体实现方法如下...,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 最近自学Python的进度比较慢,工作之余断断续续的看着效率比较低,看来还是要狠下心来每天进步一点点....‘F:\HeadFirs 本文以实例形式讲述了Python实现抓取网页并解析的功能.主要解析问答与百度的首页.分享给大家供大家参考之用.

    5.2K20

    Innodb主键包含全部列的情况下,如何组织物理页

    很简单,和有不是主键的列的格式一样。 实验:在 Mysql 8 中 创建一张主键包含全部列的表 ? 插入 10000 条数据。 ?...因为是字符串做为主键(为了好辨别),所以大小是按照字典序来的 使用工具查看叶子节点结构,下面是部分截图,剩下的部分都是 一样的 level 为0的数据页。 着重看索引叶。...也就是 level 为1的B+树叶 ? 查看索引叶(偏移量为4的数据页): ?...发现偏移量为5的数据页,含有的记录的主键最小值是 sss...0bbbbb...0 偏移量为6的数据页,含有的记录的主键最小值是sss...195bbbb...0 sss...N 这里的N是从0~10000...而112 是 1119 字典序的下一个,所以逻辑正确。虽然第11页和第5页不是物理上连续,但是两者逻辑上通过偏移量指针 5 指向 11 ,建立了逻辑联系。 并且块之间的主键大小应该是 递增的。

    57720

    10招!看骨灰级Pythoner如何玩转Python

    此参数还有另一个优点,如果你有一个同时包含字符串和数字的列,那么将其类型声明为字符串是一个好选择,这样就可以在尝试使用此列作为键去合并表时不会出错。...Map 这是一个可以进行简单数据转换的命令。首先定义一个字典,其中 keys 是旧值, values 是新值。...,并使用apply函数将其应用于列 c1 和 c2 。...缺失值的数量 构建模型时,你可能希望排除具有很多缺失值或全是缺失值的行。你可以使用.isnull()和.sum()来计算指定列中缺失值的数量。...Percentile groups 你有一个数字列,并希望将该列中的值分类为组,例如将列的前5%,分为组1,前5-20%分为组2,前20%-50%分为组3,最后50%分为组4。

    2.4K30

    涨姿势!看骨灰级程序员如何玩转Python

    此参数还有另一个优点,如果你有一个同时包含字符串和数字的列,那么将其类型声明为字符串是一个好选择,这样就可以在尝试使用此列作为键去合并表时不会出错。...df.head() 在上面的代码中,我们定义了一个带有两个输入变量的函数,并使用apply函数将其应用于列'c1'和'c2'。 但“apply函数”的问题是它有时太慢了。...例如,如果你想检查“c”列中每个值的可能值和频率,可以执行以下操作 1. df[‘c’].value_counts() 它有一些有用的技巧/参数: 1....缺失值的数量 构建模型时,你可能希望排除具有很多缺失值或全是缺失值的行。你可以使用.isnull()和.sum()来计算指定列中缺失值的数量。 1....Percentile groups 你有一个数字列,并希望将该列中的值分类为组,例如将列的前5%,分为组1,前5-20%分为组2,前20%-50%分为组3,最后50%分为组4。

    2.3K20

    盘点一个Pandas提取Excel列包含特定关键词的行(上篇)

    一、前言 前几天在Python白银交流群【上海新年人】问了一个Pandas数据提取的问题,问题如下:大佬们,请教个小问题,我要查找某列中具体的值,譬如df[df['作者'] == 'abc'],但实际上这样子我找不到...ABC,因为对方实际是小写的abc。...给了一个指导,如下所示: 全部转大写或者小写你就不用考虑了 只是不确定你实际的代码场景。后来【论草莓如何成为冻干莓】给了一份代码,如下图所示: 顺利地解决了粉丝的问题。...但是粉丝的需求又发生了改变,下一篇文章我们一起来看看这个“善变”的粉丝提问。 三、总结 大家好,我是皮皮。...这篇文章主要盘点了一个Pandas数据提取的问题,文中针对该问题,给出了具体的解析和代码实现,帮助粉丝顺利解决了问题。

    32210
    领券