--1.  当前系统日期、时间
select getdate() --2015-01-06 09:27:27.277
 
--2.时间操作 dateadd  在向指定日期加上一段时间的基础上,返回新的 datetime 值
dateadd(datepart,number,date)
注:
    datepart : year(yy, yyyy) | quarter(qq,q) | month(mm,m) | week(ww,wk) | day(dd,dy) | hour(h) | minute(mi,n) |
 second (ss,s)| millisecond(ms)
    date 参数是合法的日期表达式。number 是您希望添加的间隔数;对于未来的时间,此数是正数,对于过去的时间,此数是负数。
例:
    select getdate()                  
    select dateadd(year,1,getdate())    --2016-01-06 09:27:27.277 
    select dateadd(month,1,getdate())   --2017-02-06 09:27:27.277 
    select dateadd(day,1,getdate())     --2015-01-07 09:27:27.277
    select dateadd(week,1,getdate())    --2015-01-13 09:27:27.277
    select dateadd(weekday,1,getdate()) --2015-01-07 09:27:27.277
    select dateadd(hour,1,getdate())    --2015-01-06 10:27:27.277
    select dateadd(Minute,1,getdate())  --2015-01-06 09:28:27.277
    select dateadd(Second,1,getdate())  --2015-01-06 09:28:28.277
 
--3. datediff 返回跨两个指定日期的日期和时间边界数。
datediff( date-part, startdate, enddate )
注:
    datepart : year(yy, yyyy) | quarter(qq,q) | month(mm,m) | week(ww,wk) | day(dd,dy) | hour(h) | minute(mi,n) |
 second (ss,s)| millisecond(ms)
    startdate 和 enddate 参数是合法的日期表达式。
返回值:(enddate)-(startdate)
例:
 select datediff(year,getdate(),dateadd(year,2,getdate()))     --返回:2
 SELECT * FROM crm_contract where datediff(month,Subtime,getdate())=0  --查看crm_contract申请时间subtime是本月的数据 
 
--4. datepart 函数用于返回日期/时间的单独部分,比如年、月、日、小时、分钟等等。
--如果需要得到自己需要的日期,则需要讲日期时间格式化
SELECT DATEPART(year, getdate())    as '年份'  
SELECT DATEPART(month, getdate())   as '月份'
SELECT DATEPART(day, getdate())     as '日期'
SELECT DATEPART(week, getdate())    as  '本年第几周数'
SELECT (DATEPART(weekday, getdate())-1)  as '今天是周几?' 
SELECT DATEPART(hour, getdate())    as '小时'
SELECT DATEPART(Minute, getdate())  as '分钟' 
SELECT DATEPART(Second, getdate())  as '秒时'
 
--5. datename 返回代表指定日期的指定日期部分的字符串
SELECT datename(weekday, getdate())                  as '今天是星期几?'
SELECT datename(month,convert(varchar(10), getdate(),126)) as '今天是几月份?'
SELECT datename(day,convert(varchar(10), getdate(),126))   as '今天是几号?'
SELECT datename(year,convert(varchar(10), getdate(),126))   as '今年是哪年?'
 
--上周周一
SELECT   DATEADD(wk,   DATEDIFF(wk,0,getdate()),-7)
--上周周天
SELECT   DATEADD(wk,   DATEDIFF(wk,0,getdate()),-1)
--.本周周一
SELECT   DATEADD(wk,   DATEDIFF(wk,0,getdate()),0)
--.本周周天 
select   dateadd(wk,datediff(wk,0,getdate()),6)
--下周周一
select   dateadd(wk,datediff(wk,0,getdate()),7)
--下周周天
select   dateadd(wk,datediff(wk,0,getdate()),13)
--1.本月第一天  
SELECT   DATEADD(mm,   DATEDIFF(mm,0,getdate()),   0)  
   
--.本月最后一天  
SELECT   dateadd(ms,-3,DATEADD(mm,   DATEDIFF(m,0,getdate())+1,   0))     
--.本周星期一  
SELECT   DATEADD(wk,   DATEDIFF(wk,0,getdate()),   0) 
  
--.本周星期天   
select   dateadd(wk,datediff(wk,0,getdate()),6) 
  
--.本年第一天  
SELECT   DATEADD(yy,   DATEDIFF(yy,0,getdate()),   0)  
  
--.本年最后一天  
SELECT   dateadd(ms,-3,DATEADD(yy,   DATEDIFF(yy,0,getdate())+1,   0))    
--.本季度第一天  
SELECT   DATEADD(qq,   DATEDIFF(qq,0,getdate()),   0)  
      
--.当天的半夜  
SELECT   DATEADD(dd,   DATEDIFF(dd,0,getdate()),   0)  
      
--.上个月的最后一天  
SELECT   dateadd(ms,-3,DATEADD(mm,   DATEDIFF(mm,0,getdate()),   0))  
      
--.去年的最后一天  
SELECT   dateadd(ms,-3,DATEADD(yy,   DATEDIFF(yy,0,getdate()),   0))  
      
  
--.本月的第一个星期一  
select   DATEADD(wk,  
DATEDIFF(wk,0,dateadd(dd,6-datepart(day,getdate()),getdate())),   0)

DateADD日期Sql的更多相关文章

  1. Sql server DATEADD日期函数的使用

    DATEADD日期函数 DATEADD() 函数在日期中添加或减去指定的时间间隔. 日:在当前日期上加两天 , ,'2014-12-30') 月:在当前日期上加两个月 , , 年:在当前日期上加两年 ...

  2. DATEADD日期函数的使用

    在当前日期加上几天:https://www.cnblogs.com/shitaotao/p/7648198.html 计算本月的第一天:https://www.cnblogs.com/lcyuhe/p ...

  3. SQL Server中一些有用的日期sql语句

    SQL Server中一些有用的日期sql语句 1.一个月第一天的 SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0) 2.本周的星期一 SELECT DA ...

  4. oracle数据库查询日期sql语句(范例)、向已经建好的表格中添加一列属性并向该列添加数值、删除某一列的数据(一整列)

    先列上我的数据库表格: c_date(Date格式)     date_type(String格式) 2011-01-01                   0 2012-03-07         ...

  5. 在oracle中操作数据——使用特点的格式插入日期 sql函数的使用——日期函数

    日期函数用于处理date类型的数据,默认情况下的日期格式是dd-mm-yy即12-7月-78 (1)sysdate:该函数返回系统时间 (2)add_months(d,n) (3)last_day(d ...

  6. 日期SQL 脚本

    一个月第一天的 SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)本周的星期一     SELECT DATEADD(wk, DATEDIFF(wk,0,g ...

  7. sql求日期

    2.求以下日期SQL: 昨天 select convert(varchar(10),getdate() - 1,120) 明天 select convert(varchar(10),getdate() ...

  8. Oracle SQL函数之日期函数

    sysdate [功能]:返回当前日期. [参数]:没有参数,没有括号 [返回]:日期 SQL> SELECT SYSDATE FROM DUAL; SYSDATE ----------- // ...

  9. SQL中常用日期函数

    --1 GETDATE() 返回当前系统日期SELECT GETDATE() --2 DATEADD(日期部分,常数,日期) 返回将日期的指定日期部分加常数后的结果返回 日期部分可以是: --常数为正 ...

随机推荐

  1. 从1到n整数中1出现的次数

    题目如题 如 5 中1出现的次数 为1 12中1出现的次数为5 public class NumberOf1Between1AndN { /* *输入一个整数n,求从1到n这N个十进制表示中1出现的次 ...

  2. 简单的完全背包HDU1114

    今天广州下雨啦,不过没关系啦,反正我最近也都在刷题学习算法. 昨天做了五题01背包,今天还是背包,不过是完全背包,估计做动态规划要持续好一段时间,一开始选了一道简单题目啦. HDU1114,看了小一段 ...

  3. 关于Apple设备私有的apple-touch-icon属性详解

    以前我们用过favicon在浏览器给网站进行身份标识,用法如下: <link href="http://image.feeliu.com/web/favicon.ico" r ...

  4. html5新增操作类名方式 classList

    如果一个元素有多个类名,要如何删除呢,jqeury提供了removeClass()这个api,如果不用插件,自己封装,可以这样 function removeClass(elm,removeClass ...

  5. UltraEdit软件破解方法

    一.说明 UltraEdit破解软件虽然带有“安装说明.txt”,但是我并没有弄懂--安装说明太模糊.经过一番摸索,找到了破解方法,现记录于此. 二.操作步骤 1.断开网络 2.安装软件 3.打开软件 ...

  6. vs2008生成的各种文件

    一.sln文件     .sln(Solution)解决方案文件,表示一个项目组,他通常包含一个项目中所有的工程文件信息.   二.suo文件     suo(Solution User Option ...

  7. iOS:图像和点击事件

    问题:如何区分点的是哪张图片? // // main.m // Hello // // Created by lishujun on 14-8-28. // Copyright (c) 2014年 l ...

  8. C#委托(Delegate)学习日记

    在.NET平台下,委托类型用来定义和响应应用程序中的回调.事实上,.NET委托类型是一个类型安全的对象,指向可以以后调用的其他方法.和传统的C++函数指针不同,.NET委托是内置支持多路广播和异步方法 ...

  9. 【产品体验】echo回声

    本人产品新人,学习中,希望大家用过该产品的给点意见,不吝赐教哦~~ 先来两张echo的界面图镇楼——        echo简介: “echo”是一款做声音社交的APP,在这里,你可以感受到声音无限的 ...

  10. hadoop 各种counter 解读

    http://blog.sina.com.cn/s/blog_61ef49250100uxwh.html 经过了两天的休息与放松,精神饱满了吧?上星期我们学习了MapReduce的过程,了解了其基本过 ...