问题:

  在数据库编程开发中,有时需要获取一年前的日期,以便以此为时间的分界点,查询其前后对应的数据量。例如:

1. 想查询截止到一年前当天0点之前的数据量,以及一年前当天0点开始到现在的数据量。
2. 想查询截止到一年前当天24点之前的数据量,以及一年前当天24点开始到现在的数据量。
3. 想查询截止到一年前当月1日0点之前的数据量,以及一年前当月1日0点开始到现在的数据量。
4. 想查询截止到一年前当月最后一天24点之前的数据量,以及一年前当月最后一天24点开始到现在的数据量。

  以上这四种情况的具体查询场景,有archive数据脚本开发之前对数据库数据量的分布情况进行统计等,也有根据当前日期动态计算一年来的增量增幅情况等。

  如果每次接到这样的需求需要获取一年前日期,然后每次重新思考怎么去实现肯定是不明智的,或者说公司内已经有人写了脚本实现,但其他同事遇到相同的问题,又重新构思一次,这样就比较浪费时间和精力,耗在这个细节上一些精力,有点像要做饭可是没有米就要先去买米的感觉,而且容易造成不同人写的脚本不统一,不利于代码规范化标准化的原则,不同的人跟进的时候还要去想想之前的人写的是什么逻辑。而且重新开发脚本的话,又需要重新进行自测,不利于提高工作效率。

解决方案:

  首先简单介绍一下基本的知识点:

getdate()是获取当前日期;
dateadd可以对日期进行增减,在这里用来对年份减少1【dateadd(year, -1, 日期字符串)】,也可以用来对月份增加1【dateadd(month, 1, 日期字符串)】;
convert可以对日期进行字符串截取转换操作,在这里可以只截取形如2019-07-17的年月日【convert(varchar(10), 日期字符串, 120))】,也可以只截取形如2019-07的年月部分【convert(varchar(7), 日期字符串, 120))】。  

然后就是针对上面4个问题对应的4个解决方法:

1. 最简单,对当前日期进行减少1年的运算,然后只截取年月日。
2. 先对当前日期进行增加1天的运算,然后再减少1年,最后只截取年月日。
3. 先对当前日期进行截取年月操作,然后再指定为当月01日,再减少1年,最后只截取年月日。
4. 先对当前日期进行截取年月操作,然后再指定为当月01日,再减少1年,并加上1个月,最后只截取年月日。

  最后就可以直接在查询脚本条件中使用这个时间节点:

查询统计时间节点之前:select count(*) from 表 where 时间字段 < @datePoint

查询统计时间节点开始到现在:select count(*) from 表 where 时间字段 >= @datePoint

脚本:

/* 功能:获取一年前日期 作者:zhang502219048 脚本来源:https://www.cnblogs.com/zhang502219048/p/11198789.html*/--1.截止到一年前当天0点declare @datePoint datetime = convert(varchar(10), dateadd(year, -1, getdate()), 120)select @datePoint as DatePointgo--2.截止到一年前当天24点declare @datePoint datetime = convert(varchar(10), dateadd(year, -1, dateadd(day, 1, getdate())), 120)select @datePoint as DatePointgo--3.截止到一年前当月1日0点declare @datePoint datetime = convert(varchar(10), dateadd(year, -1, convert(varchar(7), getdate(), 120) + '-01'), 120)select @datePoint as DatePointgo--4.截止到一年前当月最后一天24点declare @datePoint datetime = convert(varchar(10), dateadd(month, 1, dateadd(year, -1, convert(varchar(7), getdate(), 120) + '-01')), 120)select @datePoint as DatePointgo

总结

更多相关文章

  1. 基于MQTT实现Android消息推送(Push)
  2. android ndk编译x264开源(用于android的ffmpeg中进行软编码)
  3. Android(安卓)Calendar使用过程中遇到的问题
  4. Android(安卓)ROM的创建和烧录
  5. Android(安卓)ASE 脚本环境
  6. DatePicker 日期选择控件 DatePickerDialog 日期选择对话框
  7. Android实现圆角弹框功能
  8. android 日期对话框
  9. android实现静默安装demo

随机推荐

  1. Android(安卓)三言两语
  2. Android交互体验必知:功能按键事件
  3. 一种绕过Android P对非SDK接口限制的简单
  4. Android webview注入自己的js代码(js传入f
  5. Android(安卓)MVP 模式:简单易懂的介绍方
  6. 第二部分:开发简要指南-第五章 支持不同的
  7. 关于android单元测试结合SAX解析xml文件
  8. 【Android的从零单排开发日记】之入门篇(
  9. 《Android移动应用基础教程》(Android Stu
  10. 年后陆续面试Android 15 家大厂,这个问题