问题描述:我们在写存储过程和函数的时候经常会碰到利用当前日期计算出上周开始日期、结束日期,或者计算上个月的开始日期结束日期等问题。最近写了几个存储过程和函数,其中都涉及到了日期计算问题,在这里简单做一个总结,留待以后查阅。

涉及知识分享:SQL中的日期计算主要涉及到GETDATE()、DATEDIFF()和DATEADD()三个方法,利用这三个方法的巧妙组合就可以得到我们想要的日期结果。首先,简单介绍一下这三个方法的定义:

(1)GETDATE():

定义:从 SQL Server 返回当前的时间和日期;

语法:GETDATE(),没有参数;

示例:select GETDATE();

结果:2016-04-26 13:35:14.670

(2)DATEDIFF()

定义:返回两个日期之间的天数;

语法:DATEDIFF(datepart,startdate,enddate), startdateenddate 参数是合法的日期表达式。datepart 参数可以是下列的值:

示例:select DATEDIFF(dd,'2016-4-21','2016-4-26');

结果:5

(3)DATEADD():

定义:在日期中添加或减去指定的时间间隔;

语法:DATEADD(datepart,number,date), date 参数是合法的日期表达式。number 是您希望添加的间隔数;对于未来的时间,此数是正数,对于过去的时间,此数是负数。datepart 参数与DATEDIFF的datepart 参数一致,参见上表。

示例:select DATEADD(dd,5,'2016-4-21');

结果:2016-04-26 00:00:00.000

具体日期计算示例:

(1)得到当前日期:

SQL: select GETDATE();

结果:2016-04-26 13:47:06.903

(2)得到本周周一日期:

SQL: select DATEADD(week,DATEDIFF(week,0,GETDATE()),0)

结果:2016-04-25 00:00:00.000

(3)得到上周周一日期(在本周周一的基础上剪掉一周即可):

SQL: select  DATEADD(week,-1,DATEADD(week,DATEDIFF(week,0,GETDATE()),0))

结果:2016-04-18 00:00:00.000

(4)得到上周周日日期,举其中两种思维方法:

第一种:先得到本周周日的日期,然后减一周

SQL: select dateadd(week,-1,DATEADD(week,DATEDIFF(week,0,getdate()),6))

结果:2016-04-24 00:00:00.000

第二种:用本周周一的日期减掉1秒

SQL: select DATEADD(ss,-1,DATEADD(week,DATEDIFF(week,0,GETDATE()),0))

结果:2016-04-24 23:59:59.000

(5)得到本月第一天日期:

SQL: select DATEADD(MM,DATEDIFF(MM,0,GETDATE()),0)

结果:2016-04-01 00:00:00.000

(6)得到上个月第一天日期(即在本月第一天日期取月的间隔数时减一即可):

SQL: select DATEADD(MM,DATEDIFF(MM,0,GETDATE())-1,0)

结果:2016-03-01 00:00:00.000

(7)得到上个月最后一天日期(即在本月第一天的基础上减掉一秒即可):

SQL: select DATEADD(SS,-1,DATEADD(MM,DATEDIFF(MM,0,GETDATE()),0))

结果:2016-03-31 23:59:59.000

关于计算两个日期间隔数DATEDIFF函数的参数0对应的日期时间问题:

在使用DATEDIFF计算日期时经常会用到参数0,参数0对应的日期是默认的日期1900-00-00 00:00:00.000,具体得到的计算间隔数由datepart参数决定。例如:

SQL:select DATEDIFF(yy,0,GETDATE()) as countYear,DATEDIFF(mm,0,GETDATE()) as countMonth,DATEDIFF(dd,0,GETDATE()) as countDay,DATEDIFF(week,0,GETDATE()) as countWeek,DATEDIFF(hh,0,GETDATE()) as countHour

结果:

  countYear countMonth countDay countWeek countHour
1 116 1395 42485 6069 1019649

数据库SQL语句中根据当前日期计算其他日期小结的更多相关文章

  1. 数据库SQL语句中 查询选修了全部课程的学生的学号和姓名

    一.SQL语言查询选修了全部课程的学生的学号和姓名. 两种解决途径: 第一种: 我们可以表示为在SC表中某个学生选修的课程数等于C表中课程总数.相应的SQL语言如下: select S#,SNAME ...

  2. Oracle数据库中,在SQL语句中连接字符串的方法是哪个?(选择1项)

    Oracle数据库中,在SQL语句中连接字符串的方法是哪个?(选择1项) A.cat B.concat C.join D.+ 解答:B

  3. SQL语句中日期的计算方法大全

    sql语句中的日期处理一.日期處理函數1.日期增減函數 dateadd(datepart,number,dtae) datepart:是規定應向日期的哪一部分返回新值的參數.下列是sql server ...

  4. 学生选课数据库SQL语句45道练习题整理及mysql常用函数(20161019)

    学生选课数据库SQL语句45道练习题: 一.            设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher).四 ...

  5. 数据库 SQL语句优化

    温馨提示:本篇内容均来自网上,本人只做了稍微处理,未进行细致研究,仅当做以后不备之需,如若你喜欢可尽情转走. 一.问题的提出 在应用系统开发初期,由于开发数据库数据比较少,对于查询SQL语句,复杂视图 ...

  6. (转载)SQL语句中Group by语句的详细介绍

    转自:http://blog.163.com/yuer_d/blog/static/76761152201010203719835 SQL语句中Group by语句的详细介绍              ...

  7. SQL点滴35—SQL语句中的exists

    原文:SQL点滴35-SQL语句中的exists 比如在Northwind数据库中有一个查询为 SELECT c.CustomerId,CompanyName FROM Customers c WHE ...

  8. 数据库SQL语句性能优化

    选择最有效率的表名顺序 ORACLE的解析器按照从右到左的顺序处理FROM子句中的表名,FROM子句中写在最后的表(基础表 driving table)将被最先处理,在FROM子句中包含多个表的情况下 ...

  9. sql语句中的[]中括号(转)

    下面有关sql语句中[]的信息适用于Sql Server.Access等多种数据库. 1.sql语句中加[]是为了防止歧义,避免与系统保留关键字冲突,使计算机能识别.sql语句中有些字段可能是关键字, ...

随机推荐

  1. 【面向对象版】HashMap(增删改查)

    前言: 关于什么是HashMap,HashMap可以用来做些什么,这些定义类的描述,请参照[简易版]HashMap(增删改查)的内容. 这章节主要是面向实例,直接进行HashMap(增删改查)的演示. ...

  2. Java 零基础之作业小练习

    [练习1] 需求:输入学员的名称及总科目数并显示每项科目成绩的分数,算出总成绩. package demo2; import java.util.Scanner; //先import Scanner语 ...

  3. 修改Shp文件名称

    IWorkspaceFactory factory = new ShapefileWorkspaceFactoryClass(); IWorkspace pworkspace = factory.Op ...

  4. c++学习笔记01-输入输出流&&文件输入输出操作

    const int size=50等于#define size 50 字符串默认以0结尾: 一.输入输出流 cin.get()会从输入中取走一个字符: cin.peek()会从输入中检测第一个字符: ...

  5. 安装android

    http://www.oschina.net/question/1463998_220998 http://www.cnblogs.com/zoupeiyang/p/4034517.html

  6. Struts——(四)异常处理机制

    在通常的情况下,我们得到异常以后,需要将页面导航到一个错误提示的页面,提示错误信息.利用Stuts我们可以采用两种方式处理异常: 1.编程式异常处理 即我们在Action中调用业务逻辑层对象的方法时, ...

  7. Android WIFI 分析(一)

    本文基于<深入理解Android WiFi NFC和GPS 卷>和 Android N 代码结合分析   WifiService 是 Frameworks中负责wifi功能的核心服务,它主 ...

  8. iOS 9/10强制使用https访问网络,使用了第三方SDK的应用需要配置的信息

    2017年01月01日起苹果将全面禁止使用http来访问网络. 网上扒了一些资源,解决方法还是有的,但是都不确定是否可以通过审核,毕竟实践才是检验真理的唯一标准. 后续如果上线成功,再来分享. 如果应 ...

  9. css之absolute绝对定位(绝对定位特性)

    学习了绝对定位以后,对此进行一个总结,啦啦啦啦~ 绝对定位特性 1.破坏性 破坏了原有的位置,从文档流里脱离出来 2.包裹性 如果下面这种情况,父级元素将不会有高度和宽度,失去原有的大小

  10. ext.ajax.request请求时带有遮罩效果

    ajax请求时有时需要操作大量的数据,反应有时会很慢,这时我们想要来一个遮罩效果,具体步骤如下 1.定义一个遮罩 var myMask = new Ext.LoadMask(Ext.getBody() ...