首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >要按天分组的SQL查询

要按天分组的SQL查询
EN

Stack Overflow用户
提问于 2009-11-02 05:13:35
回答 8查看 224.5K关注 0票数 153

我想列出所有的销售额,并按天对总数进行分组。

代码语言:javascript
复制
Sales (saleID INT, amount INT, created DATETIME)

注意:我使用的是SQL Server 2005。

EN

回答 8

Stack Overflow用户

发布于 2009-11-02 05:22:30

如果您正在使用SQL Server,

dateadd(DAY,0, datediff(day,0, created))将返回创建的日期

例如,如果销售创建于'2009-11-02 06:12:55.000',则dateadd(DAY,0, datediff(day,0, created))返回'2009-11-02 00:00:00.000‘

代码语言:javascript
复制
select sum(amount) as total, dateadd(DAY,0, datediff(day,0, created)) as created
from sales
group by dateadd(DAY,0, datediff(day,0, created))
票数 189
EN

Stack Overflow用户

发布于 2009-11-02 05:25:47

对于SQL Server:

代码语言:javascript
复制
GROUP BY datepart(year,datefield), 
    datepart(month,datefield), 
    datepart(day,datefield)

或更快(来自Q8-Coder):

代码语言:javascript
复制
GROUP BY dateadd(DAY,0, datediff(day,0, created))

对于MySQL:

代码语言:javascript
复制
GROUP BY year(datefield), month(datefield), day(datefield)

或者更好(来自Jon Bright):

代码语言:javascript
复制
GROUP BY date(datefield)

对于Oracle:

代码语言:javascript
复制
GROUP BY to_char(datefield, 'yyyy-mm-dd')

或更快(来自IronGoofy):

代码语言:javascript
复制
GROUP BY trunc(created);

For Informix ( Jonathan Leffler撰写):

代码语言:javascript
复制
GROUP BY date_column
GROUP BY EXTEND(datetime_column, YEAR TO DAY)
票数 131
EN

Stack Overflow用户

发布于 2009-11-02 05:23:39

如果您使用的是MySQL:

代码语言:javascript
复制
SELECT
    DATE(created) AS saledate,
    SUM(amount)
FROM
    Sales
GROUP BY
    saledate

如果您使用的是MS SQL 2008:

代码语言:javascript
复制
SELECT
    CAST(created AS date) AS saledate,
    SUM(amount)
FROM
    Sales
GROUP BY
    CAST(created AS date)
票数 57
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1658340

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档