转载:SQL按照⽇、周、⽉、年统计数据

本文介绍了SQL中对日期的处理方法,包括按日、周、月、季、年的聚合查询,以及使用DATEPART和DATE_FORMAT函数进行日期截取和格式化。同时,文章通过示例展示了在实际操作中可能出现的错误及其解决方案,帮助读者更好地理解和应用SQL日期处理技巧。
摘要由CSDN通过智能技术生成

转载源:http://www.jb51.net/article/42613.htm

⽅式⼀:
--按⽇
select sum(consume),day([date]) from consume_record where year([date]) = '2006' group by day([date])
--按周quarter 
select sum(consume),datename(week,[date]) from consume_record where year([date]) = '2006' group by datename(week,[date])
--按⽉
select sum(consume),month([date]) from consume_record where year([date]) = '2006' group by month([date])
--按季
select sum(consume),datename(quarter,[date]) from consume_record where year([date]) = '2006' group by datename(quarter,[date]) 
--按年
select sum(consume),year([date]) from consume_record where  group by year([date])
⽅式⼆:
sqlserver 截取⽇期年份和⽉份使⽤datepart函数,函数使⽤⽅法如下:
⼀、函数功能:DATEPART() 函数⽤于返回⽇期/时间的单独部分,⽐如年、⽉、⽇、⼩时、分钟等等。
⼆、语法:DATEPART(datepart,date)
三、参数说明:date 参数是合法的⽇期表达式。datepart 参数可以是下列的值:
四、实例
1、截取年份:datepart(yy,'2017-1-1') 返回:2017
2、截取⽉份:datepart(mm,'2017-1-1') 返回:1
五、datepart函数返回的是整型数值,如果需要返回字符型,那么使⽤datename()函数,⽤法与datepart相同,只是返回数据类型不同。
 

常见错误
--选择列表中的列 'dbo.v_yjdatealljg.cjrq' ⽆效,因为该列没有包含在聚合函数或 GROUP BY ⼦句中。
--把所有按组排序的依据都加上 yjxzqid, cjdd, ncpid, YEAR([cjrq]), month([cjrq])
--去掉农产品名称 ncpmc
SELECT yjxzqid, cjdd, ncpid, YEAR([cjrq]) as [year], month([cjrq]) as [month], avg( ttjg)as ttjg, avg(pfjg)as pfjg, avg(lsjg)as lsjg
FROM dbo.v_yjdatealljg group by yjxzqid, cjdd, ncpid, YEAR([cjrq]), month([cjrq])
DATE_FORMAT
1
selectDATE_FORMAT(create_time,'%Y%u') weeks,count(caseid) countfromtc_case groupbyweeks;
2
selectDATE_FORMAT(create_time,'%Y%m%d') days,count(caseid) countfromtc_case groupbydays;
3
selectDATE_FORMAT(create_time,'%Y%m') months,count(caseid) countfromtc_case groupbymonths;
DATE_FORMAT(date,format) 
根据format字符串格式化date值。下列修饰符可以被⽤在format字符串中:
%M ⽉名字(January……December) 
%W 星期名字(Sunday……Saturday) 
%D 有英语前缀的⽉份的⽇期(1st, 2nd, 3rd, 等等。)
%Y 年, 数字, 4 位
%y 年, 数字, 2 位
%a 缩写的星期名字(Sun……Sat) 
%d ⽉份中的天数, 数字(00……31) 
%e ⽉份中的天数, 数字(0……31
%m ⽉, 数字(01……12) 
%c ⽉, 数字(1……12) 
%b 缩写的⽉份名字(Jan……Dec) 
%j ⼀年中的天数(001……366) 
%H ⼩时(00……23) 
%k ⼩时(0……23) 
%h ⼩时(01……12) 
%I ⼩时(01……12) 
%l ⼩时(1……12) 
%i 分钟, 数字(00……59) 
%r 时间,12 ⼩时(hh:mm:ss [AP]M) 
%T 时间,24 ⼩时(hh:mm:ss) 
%S 秒(00……59) 
%s 秒(00……59) 
%p AM或PM 
%w ⼀个星期中的天数(0=Sunday ……6=Saturday )
%U 星期(0……52), 这⾥星期天是星期的第⼀天
%u 星期(0……52), 这⾥星期⼀是星期的第⼀天
%% ⼀个⽂字“%”。
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值