ora-00979: not a group by expression

时间: 2023-04-28 18:03:29 浏览: 94
ORA-00979 错误是一个 Oracle 数据库的错误代码,它表示 SQL 查询语句中的 GROUP BY 子句使用不当。 在使用 GROUP BY 子句时,需要将 SELECT 语句中所有的列都包含在 GROUP BY 子句中,以确保查询结果正确。如果 SELECT 语句中的列没有全部包含在 GROUP BY 子句中,就会出现 ORA-00979 错误。 解决这个问题的方法是,检查 SQL 查询语句中的 GROUP BY 子句,并确保其中包含了 SELECT 语句中的所有列。如果查询中使用了聚合函数,比如 SUM、COUNT、AVG 等,也需要将这些列包含在 GROUP BY 子句中。
相关问题

> ora-00979: not a group by expression

ORA-00979是Oracle数据库的错误代码,表示在使用GROUP BY语句时,SELECT语句中的某些列没有被包含在GROUP BY子句中。 这个错误通常发生在使用聚合函数(如SUM、AVG、COUNT等)时,因为这些函数需要将数据按照指定的列进行分组计算。如果SELECT语句中的列没有被包含在GROUP BY子句中,Oracle就无法确定如何对这些列进行分组计算,从而导致错误。 解决这个问题的方法是在GROUP BY子句中包含所有SELECT语句中的列,或者使用聚合函数对这些列进行计算。例如,如果SELECT语句中包含了列A、B和C,那么正确的GROUP BY子句应该是GROUP BY A, B, C,或者使用聚合函数对这些列进行计算,例如SELECT A, SUM(B), AVG(C) FROM table GROUP BY A。

但是这样会报错:ORA-00979: not a GROUP BY expression

是的,您是正确的,如果使用通配符 "*" 来选择所有列,那么在 GROUP BY 子句中也必须包含所有选择的列,否则会出现 ORA-00979 错误,因为在 GROUP BY 子句中必须包含 SELECT 列表中的所有非聚合列。 如果您想选择所有列,可以将所有列都列出来,如下所示: ``` SELECT a.*, b.*, c.* FROM sipm9 a, sipm9_objof b, sipm12 c WHERE a.id = b.itemid1 AND b.itemid2 = c.id GROUP BY a.id, a.name, b.col1, b.col2, ..., c.col1, c.col2, ... HAVING SUM(c.id) > 5; ``` 需要将所有列都列出来,这可能会使查询变得冗长,并且当表结构发生变化时,需要手动更新查询。因此,建议在 SELECT 子句中明确列出需要的列,而不是使用通配符。

相关推荐

最新推荐

recommend-type

Oracle dbca时报:ORA-12547: TNS:lost contact错误的解决

最近在工作中遇到了一个问题,错误是Oracle dbca时报错:ORA-12547: TNS:lost contact,通过查找相关的资料终于找到了解决的方法,下面分享给大家,话不多说了,来一起看看详细的介绍吧。 环境: OS:RHEL6.5 x86-...
recommend-type

解决oracle12c创建用户提示ORA-65096:公用用户名或角色无效问题

主要介绍了解决oracle12c创建用户提示ORA-65096:公用用户名或角色无效问题,需要的朋友可以参考下
recommend-type

oracle远程连接服务器出现 ORA-12170 TNS:连接超时 解决办法

oracle远程连接服务器出现 ORA-12170 TNS:连接超时 解决办法,需要的朋友可以参考一下
recommend-type

oracle报错(ORA-00600)问题处理

ORA-00600:internalerrorcode,arguments:[kcblasm_1],[103],[],[],[],[],[],[] TueAug1209:20:17CST2014 Errorsinfile/u01/app/oracle/admin/orcl/udump/orcl_ora_29974.trc: ORA-00600:internalerrorcode,arguments...
recommend-type

6-10.py

6-10
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

2. 通过python绘制y=e-xsin(2πx)图像

可以使用matplotlib库来绘制这个函数的图像。以下是一段示例代码: ```python import numpy as np import matplotlib.pyplot as plt def func(x): return np.exp(-x) * np.sin(2 * np.pi * x) x = np.linspace(0, 5, 500) y = func(x) plt.plot(x, y) plt.xlabel('x') plt.ylabel('y') plt.title('y = e^{-x} sin(2πx)') plt.show() ``` 运行这段
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。