zoukankan      html  css  js  c++  java
  • SQL Server 日期和时间函数

    1、常用日期方法(下面的GetDate() = '2006-11-08 13:37:56.233')

    (1)DateName( datepart ,date )

       返回表示指定日期的指定日期部分的字符串。Datepart详见下面的列表.

    Select Datename(Day, Getdate()) --返回 8

    (2)DATEPART ( datepart , date )

        返回表示指定日期的指定日期部分的整数。

    Select Datepart(Year, Getdate()) --返回2006

    (3)DATEADD (datepart , number, date )

        返回给指定日期加上一个时间间隔后的新datetime 值。

    Select Dateadd(week, 1, Getdate()) --当前日期加一周后的日期

    (4)DATEDIFF ( datepart , startdate , enddate )

    返回跨两个指定日期的日期边界数和时间边界数。

    Select Datediff(Month, '2006-10-11', '2006-11-01')  --返回1

    (5)DAY ( date )

    返回一个整数,表示指定日期的天datepart 部分。

    Select Day(Getdate()) --日期为:2014-11-08 08:56:45.903,返回8

    (6)GETDATE()

    以datetime 值的SQL Server 2005 标准内部格式返回当前系统日期和时间。

    Select Getdate() --返回2006-11-08 13:37:56.2

    (7)MONTH ( date )

    返回表示指定日期的“月”部分的整数。

    Select Month(Getdate()) --返回

    (8)YEAR ( date )

    返回表示指定日期的“年”部分的整数。

    Select Year(Getdate()) --返回2006


    2、取特定日期

    (1)获得当前日期是星期几

    Select Datename(weekday, Getdate()) --Wednesday

    (2)计算哪一天是本周的星期一

    Select Dateadd( week, Datediff(week, '1900-01-01', Getdate()), '1900-01-01' )  --返回2006-11-06 00:00:00.000
    --
    Select Dateadd(week, Datediff(week, 0, Getdate()), 0)

    (3)当前季度的第一天

    Select Dateadd(quarter, Datediff(quarter, 0, Getdate()), 0)  --返回2006-10-01 00:00:00.0

    (4)如何取得某个月的天数

    Select Day( Dateadd(ms, -3, Dateadd(mm, Datediff(m, 0, '2006-02-03') + 1, 0))) --返回28

    (5)一个季度多少天

     

    Declare @m Tinyint, @time Smalldatetime
    
    Select @m = Month(Getdate()) 
    Select @m = Case 
                     When @m Between 1 And 3 Then 1
                     When @m Between 4 And 6 Then 4
                     When @m Between 7 And 9 Then 7
                     Else 10
                End
    
    Select @time = Datename(Year, Getdate()) + '-' + Convert(Varchar(10), @m) + '-01' 
    Select Datediff(Day, @time, Dateadd(mm, 3, @time)) --返回92


    (6)获得年月日(yyyy-MM-dd)

    Select Convert(Varchar(10), Getdate(), 120) --返回2006-11-

    3、其它

    (1)--下面的示例将日期指定为数字。数据库引擎将0 解释为1900 年1 月1 日。

    Select Month(0), Day(0), Year(0)
    --下面两句是等效的
    Select Datename(WEEKDAY, 0)
    Select Datename(WEEKDAY, '1900-01-01')


    (2)SET DATEFIRST { number | @number_var }

    将一周的第一天设置为从1 到7 的一个数字。

    Set Datefirst 1 --表示一周的第一天是“星期一"
    Select Datename(WEEKDAY, Getdate())  --Wednesday
    Select Datepart(weekday, Getdate()) --返回3
    Select @@DATEFIRST  --查看当前设置情况


    (3)SET DATEFORMAT { format | @format_var }

    设置用于输入datetime 或smalldatetime 数据的日期部分(月/日/年)的顺序。
    ...有效参数包括mdy、dmy、ymd、ydm、myd 和dym。
    ...该设置仅用在将字符串转换为日期值时的解释中。它不影响日期值的显示。
    ...SET DATEFORMAT 的设置是在执行或运行时设置,而不是在分析时设置。
    ...SET DATEFORMAT 将覆盖SET LANGUAGE 的隐式日期格式设置。
    下面是例子:

    -- Set date format to year, day, month.
    Set Dateformat ydm;
    Go
    Declare @datevar Datetime;
    Set @datevar = '1998/31/12';
    Select @datevar As DateVar;
    Go
    -- Set date format to year, month, day.
    Set Dateformat ymd;
    Go
    Declare @datevar Datetime;
    Set @datevar = '1998/12/31';
    Select @datevar As DateVar;
    Go


    (4)日期部分的列表

    日期部分

    缩写

    year

    yy, yyyy

    quarter

    qq, q

    month

    mm, m

    dayofyear

    dy, y

    day

    dd, d

    week

    wk, ww

    weekday

    dw

    hour

    hh

    minute

    mi, n

    second

    ss, s

    millisecond

    ms

    数据类型

    范围

    精确度

    datetime

    1753 年 1 月 1 日到 9999 年 12 月 31 日

    3.33 毫秒

    smalldatetime

    1900 年 1 月 1 日到 2079 年 6 月 6 日

  • 相关阅读:
    Format用法总汇
    packed record与record区别
    将实数取整函数
    取鼠标所在位置对应的窗口句柄
    Delphi中优秀的字符串分割函数
    Jscript中的FSO对象模式
    关于.NET开发中遇到的一个验证视图状态Mac失败的解决方法随笔
    如何延长电脑硬盘的使用寿命
    如何避免U盘中毒
    如何优化Windows XP系统来加快网速
  • 原文地址:https://www.cnblogs.com/wolfocme110/p/4094016.html
Copyright © 2011-2022 走看看