按年份、季度、月份、日期查询SQL语句

  在做报表的时候项目需求是按年份、季度、月份或者日期查询数据,这些要求都是按时间段来查询数据。但和我们的时间段查询又有些不同。其实,报表中的按年份、季度、月份或者日期查询的基本步骤可以划分为两个小步骤:

第一、添加时间段的字段放在虚表中,比如 :

SELECT  
       CountMoney,   
	  SubscribeSeat,
	  RderDate,
	  year(RderDate)*10000+1+100 as Yeartime,
	  year(RderDate)*10000+1+100*(month(RderDate)-(month(RderDate)-1)%3) as seasontime,
	  year(RderDate)*10000+1+ month(RderDate)*100 as Mouthtime,
	  year(RderDate)*10000+ month(RderDate)*100+DAY(RderDate) as Daytime
 FROM  Best_Indent

输出结果:
在这里插入图片描述
说明:按年份 year(RderDate)*10000+1+100 as Yeartime,
按季节 year(RderDate)10000+1+100(month(RderDate)-(month(RderDate)-1)%3) as Seasontime,
按月份 year(RderDate)*10000+1+ month(RderDate)*100 as Mouthtime,
按日期 year(RderDate)*10000+month(RderDate)*100+Day(RderDate) as Daytime,

第二、根据时间段分组查询,还可以根据项目需求进行修改语句。下面是按季度查询

SELECT NewTable.Seasontime as '季度', sum(NewTable.CountMoney) as '总金额',
        SUM(NewTable.SubscribeSeat) as '订单数' FROM 
	(SELECT
	   CountMoney,   
     SubscribeSeat,
	   RderDate,
	   year(RderDate)*10000+1+100 as Yeartime,
	   year(RderDate)*10000+1+100*(month(RderDate)-(month(RderDate)-1)%3) as Seasontime,
	   year(RderDate)*10000+1+ month(RderDate)*100 as  Mouthtime,
	   year(RderDate)*10000+ month(RderDate)*100+DAY(RderDate) as Daytime
   FROM Best_Indent) as  NewTable 
    GROUP BY NewTable.Seasontime

输出结果:
在这里插入图片描述
  个人总结:在看项目需求的时候,我一直在思考这个SQL语句应该怎么实现呢!原本我以为很难的事情,没想到进过我仔细思考了一下。其实,也没有我想象中那么复杂,那些所谓难的问题,它的基层都是由那些比较基础的东西构成的。从中让我明白了一个道理,当遇到比较难的问题的时候,请静下心来想一想基础性的东西,或许对你有帮助哦!所谓的繁杂的东西都是有基础性的东西构成,不同点在于简单的东西都放在一下,就让问题思考起来没有那么简单啦!在我们的学习过程中一定要把基础的东西牢固,以后的路就走的比较顺畅一些。有些学者在学基础性的东西,觉得这么简单的东西,不学也会了。就有一种轻视的心理,可到最后才发现自己什么也不会,这时候才悟觉出来基础的重要性。

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值