sql - GROUP BY 在 Oracle 11g 中不起作用

标签 sql oracle11g

我有一张 table

expenses (
    purchase_date date, 
    item_purchased varchar2(15),
    amount number
)

我想对购买日期(日期列)执行“分组依据”。 说,我必须这样做:

SELECT purchase_date, count(*) 
FROM expenses 
GROUP BY purchase_date;

它给我的结果是:

purchase_date    count
-------------   -------
19-Jul-12           1
20-Jul-12           1

虽然我有多个属于同一天的条目

我正在使用 Oracle 11g。我的一位 friend 使用 Oracle 10g,相同的查询在她的版本中按预期工作。那么 11g 有什么问题呢?

请帮助我的 friend 。

TIA。 :)

最佳答案

DATE 列还包含一天中的时间。不幸的是,SQL*Plus(您似乎正在使用)在默认配置中不显示时间。

要摆脱聚合期间的时间,请使用 trunc() 函数:

SELECT trunc(purchase_date), count(*) 
FROM expenses 
GROUP BY trunc(purchase_date);

如果这没有改变结果,那么您的数据很可能不是您认为的那样。然后您应该发布一个独立的测试用例(包括用于创建测试数据的 INSERT 语句)。你可以在 http://sqlfiddle.com 做到这一点

关于sql - GROUP BY 在 Oracle 11g 中不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11556382/

相关文章:

oracle - 程序中出现奇怪错误 "Ora-01001 Invalid cursor"

SQL Reporting Services 空字符串处理

c# - 为什么这个查询返回-1?

c# - 使用 12c 客户端截断的存储过程 OUTPUT VARCHAR2 值

java - 使用statement.executeQuery编写的Select语句无法选择具有-(破折号)的值

java - OIM 中的实体管理器

sql - 按寄存器显示所有授权

mysql - 从 BINARY 直接转换为 INT,绕过中间 CHAR

sql - 如何有效地对 SQL 数据库中的记录进行版本控制

sql - Oracle SQL 案例