Count days in date range?

半城伤御伤魂 提交于 2019-12-02 03:28:51

问题


I have a query like this:

SELECT COUNT(*) AS amount
FROM daily_individual_tracking
WHERE sales = 'YES'
AND daily_individual_tracking_date BETWEEN '2010-01-01' AND '2010-03-31'

I am selected from a date range. Is there a way to also get the total days in the date range?


回答1:


Not really clear if you are looking for

DATEDIFF('2010-03-31', '2010-01-01')

or

COUNT(DISTINCT daily_individual_racking_date)



回答2:


What exactly are you trying to count? The total number of distinct values of daily_individual_tracking_date? Do you need it in the same query as the count(*) query?




回答3:


This depends on what SQL server you're using.

If you're using MS-SQL Server, you can use the function DateDiff




回答4:


I'm not sure which SQL you are using. TSQL has a DATEDIFF that will count the number of days between two dates. See this




回答5:


You can use the MySQL datediff function:

SELECT DATEDIFF('2010-01-01','2010-01-31') AS DiffDays

It should return a floating point, where 1.0 represents a single day.

And for MS SQL use ,

SELECT DATEDIFF( day ,'2010-01-01','2010-01-31') AS DiffDays


来源:https://stackoverflow.com/questions/2602130/count-days-in-date-range

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!