作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一张 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/
我是一名优秀的程序员,十分优秀!