<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    憨厚生

    ----Java's Slave----
    ***Java's Host***

      BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
      165 隨筆 :: 17 文章 :: 90 評(píng)論 :: 0 Trackbacks
     轉(zhuǎn) http://www.cnblogs.com/coconut_zhang/archive/2009/02/02/1382598.html

    SQLServer時(shí)間日期函數(shù)詳解,SQLServer,時(shí)間日期,

    1.      當(dāng)前系統(tǒng)日期、時(shí)間

            select getdate()

    2. dateadd      在向指定日期加上一段時(shí)間的基礎(chǔ)上,返回新的 datetime 值

           例如:向日期加上2天

           select dateadd(day,2,'2004-10-15')      --返回:2004-10-17 00:00:00.000

    3. datediff 返回跨兩個(gè)指定日期的日期和時(shí)間邊界數(shù)。

           select datediff(day,'2004-09-01','2004-09-18')       --返回:17

           select datediff(day,'2004-09-18','2004-09-01')       --返回:-17

    4. datepart 返回代表指定日期的指定日期部分的整數(shù)。

          SELECT DATEPART(month, '2004-10-15')      --返回 10

    5. datename 返回代表指定日期的指定日期部分的字符串

           SELECT datename(weekday, '2004-10-15')      --返回:星期五

    6. day(), month(),year() --可以與datepart對(duì)照一下

    select 當(dāng)前日期=convert(varchar(10),getdate(),120)

    ,當(dāng)前時(shí)間=convert(varchar(8),getdate(),114)

    select datename(dw,'2004-10-15')

    select 本年第多少周=datename(week,'2004-10-15')

              ,今天是周幾=datename(weekday,'2004-10-15')

    函數(shù) 參數(shù)/功能

    GetDate( )   返回系統(tǒng)目前的日期與時(shí)間

    DateDiff (interval,date1,date2) 以interval 指定的方式,返回date2 與date1兩個(gè)日期之間的差值

    date2-date1

    DateAdd (interval,number,date) 以interval指定的方式,加上number之后的日期

    DatePart (interval,date) 返回日期date中,interval指定部分所對(duì)應(yīng)的整數(shù)值

    DateName (interval,date) 返回日期date中,interval指定部分所對(duì)應(yīng)的字符串名稱

    參數(shù) interval的設(shè)定值如下:

    值 縮 寫(Sql Server) (Access 和 ASP) 說明

    Year Yy yyyy 年 1753 ~ 9999

    Quarter Qq q    季 1 ~ 4

    Month Mm m    月1 ~ 12

    Day of year Dy y   一年的日數(shù),一年中的第幾日 1-366

    Day Dd d    日,1-31

    Weekday Dw w 一周的日數(shù),一周中的第幾日 1-7

    Week Wk ww   周,一年中的第幾周 0 ~ 51

    Hour Hh h    時(shí)0 ~ 23

    Minute Mi n   分鐘0 ~ 59

    Second Ss s 秒 0 ~ 59

    Millisecond Ms - 毫秒 0 ~ 999

    access 和 asp 中用date()和now()取得系統(tǒng)日期時(shí)間;其中DateDiff,DateAdd,DatePart也同是能用于

    Access和asp中,這些函數(shù)的用法也類似

    舉例:

    1.GetDate() 用于sql server :select GetDate()

    2.DateDiff('s','2005-07-20','2005-7-25 22:56:32')返回值為 514592 秒

    DateDiff('d','2005-07-20','2005-7-25 22:56:32')返回值為 5 天

    3.DatePart('w','2005-7-25 22:56:32')返回值為 2 即星期一(周日為1,周六為7)

    DatePart('d','2005-7-25 22:56:32')返回值為 25即25號(hào)

    DatePart('y','2005-7-25 22:56:32')返回值為 206即這一年中第206天

    DatePart('yyyy','2005-7-25 22:56:32')返回值為 2005即2005年

    具體的語法:

    日期函數(shù)用來操作DATETIME 和SMALLDATETIME 類型的數(shù)據(jù),執(zhí)行算術(shù)運(yùn)算。與其它函數(shù)一樣,可以在

    Select 語句的Select 和Where 子句以及表達(dá)式中使用日期函數(shù)。其使用方法如下:

    日期函數(shù)參數(shù),其中參數(shù)個(gè)數(shù)應(yīng)不同的函數(shù)而不同。

    ·DAY()

    DAY() 函數(shù)語法如下:

    DAY (<date_expression>)

    DAY() 函數(shù)返回date_expression 中的日期值。

    ·MONTH()

    MONTH() 函數(shù)語法如下:

    MONTH (<date_expression>)

    MONTH() 函數(shù)返回date_expression 中的月份值。

    與DAY() 函數(shù)不同的是,MONTH() 函數(shù)的參數(shù)為整數(shù)時(shí),一律返回整數(shù)值1,即SQL Server 認(rèn)為其

    是1900 年1 月。

    ·YEAR()

    YEAR() 函數(shù)語法如下:

    YEAR (<date_expression>)

    YEAR() 函數(shù)返回date_expression 中的年份值。

    提醒:在使用日期函數(shù)時(shí),其日期值應(yīng)在1753年到9999年之間,這是SQL Server系統(tǒng)所能識(shí)別的日期范

    圍,否則會(huì)出現(xiàn)錯(cuò)誤。

    ·DATEADD()

    DATEADD() 函數(shù)語法如下:

    DATEADD (<datepart>, <number>, <date>)

    DATEADD() 函數(shù)返回指定日期date 加上指定的額外日期間隔number 產(chǎn)生的新日期。參數(shù)“datepart

    ” 在日期函數(shù)中經(jīng)常被使用,它用來指定構(gòu)成日期類型數(shù)據(jù)的各組件,如年、季、月、日、星期等。

    其取值如表4-9 所示:

    ·DATEDIFF()

    DATEDIFF() 函數(shù)語法如下:

    DATEDIFF() (<datepart>, <date1>, <date2>)

    DATEDIFF() 函數(shù)返回兩個(gè)指定日期在datepart 方面的不同之處,即date2 超過date1的差距值,其

    結(jié)果值是一個(gè)帶有正負(fù)號(hào)的整數(shù)值。針對(duì)不同的datepart, DATEDIFF()函數(shù)所允許的最大差距值不

    一樣,如:datepart 為second 時(shí),DATEDIFF() 函數(shù)所允許的最大差距值為68: 年datepart 為

    millisecond 時(shí),DATEDIFF() 函數(shù)所允許的最大差距值為24 天20 小時(shí)30 分23 秒647 毫秒。

    ·DATENAME()

    DATENAME() 函數(shù)語法如下:

    DATENAME (<datepart>, <date)>

    DATENAME() 函數(shù)以字符串的形式返回日期的指定部分此部分。由datepart 來指定。

    ·DATEPART()

    DATEPART() 函數(shù)語法如下:

    DATEPART (<datepart>, <date>)

    DATEPART() 函數(shù)以整數(shù)值的形式返回日期的指定部分。此部分由datepart 來指定。

    DATEPART (dd, date) 等同于DAY (date)

    DATEPART (mm, date) 等同于MONTH (date)

    DATEPART (yy, date) 等同于YEAR (date)

    ·GETDATE()

    GETDATE() 函數(shù)語法如下:

    GETDATE()

    GETDATE() 函數(shù)以DATETIME 的缺省格式返回系統(tǒng)當(dāng)前的日期和時(shí)間,它常作為其它函數(shù)或命令的參

    數(shù)使用。

    在開發(fā)數(shù)據(jù)庫應(yīng)用中,經(jīng)常會(huì)遇到處理時(shí)間的問題,如查詢指定時(shí)間的記錄等。下面就這些常見的問題

    ,結(jié)合自己的一些經(jīng)驗(yàn),和大家探討一下這類問題。

      首先介紹一下,SQL Server里處理時(shí)間的幾個(gè)主要函數(shù)的用法:

    getdate()函數(shù):取得系統(tǒng)當(dāng)前的日期和時(shí)間。返回值為datetime類型的。

    用法:getdate()

    例子:

    select getdate() as dte,dateadd(day,-1,getdate()) as nowdat

    輸出結(jié)果:

    dte nowdat

    1999-11-21 19:13:10.083 1999-11-20 19:13:10.083

    (1 row(s) affected)

    datepart()函數(shù):以整數(shù)的形式返回時(shí)間的指定部分。

    用法:datepart(datepart,date)

    參數(shù)說明:datepart時(shí)要返回的時(shí)間的部分,常用取值year、month、day、hour、minute。

    date是所指定的時(shí)間。

    例子:

    SELECT DATEPART(month, GETDATE()) AS 'Month Number'

    輸出結(jié)果:

    Month Number

    11

    (1 row(s) affected)

    dateadd()函數(shù):通過給指定的時(shí)間的指定部分加上一個(gè)整數(shù)值以返回一個(gè)新時(shí)間值。

    用法:dateadd(datepart,number,date)

    參數(shù)說明:datepart(同上)

    date(同上)

    number要增加的值,整型,可正可負(fù),正值返回date之后的時(shí)間值,負(fù)值返回date

    之前的時(shí)間值

    例子:

    select getdate() as today

    select dateadd(day,-1,getdate())

    select dateadd(day,1,getdate())

    輸出:

    today

    1999-11-21 19:42:41.410

    (1 row(s) affected)

    yesterday

    1999-11-20 19:42:41.410

    (1 row(s) affected)

    tomorrow

    1999-11-22 19:42:41.410

    (1 row(s) affected)

    datediff()函數(shù):返回兩個(gè)時(shí)間以指定時(shí)間部分來計(jì)算的差值。返回整數(shù)值。如1991-6-12和1991-6-21

    之間以天

    來算相差9天,1998-6-12和1999-6-23按年算相差1年,1999-12-1和1999-3-12按月算相差9個(gè)月

    用法:datediff(darepart,date1,date2)

    參數(shù)說明:datepart(同上)

    date1、date2(同上date)

    例子:

    select datediff(month,'1991-6-12','1992-6-21') as a

    posted on 2009-06-22 12:56 二胡 閱讀(1905) 評(píng)論(0)  編輯  收藏 所屬分類: pl/sql
    主站蜘蛛池模板: 免费欧洲毛片A级视频无风险| 亚洲爆乳少妇无码激情| 免费国产真实迷j在线观看| 久久99国产综合精品免费| 羞羞漫画小舞被黄漫免费| 91亚洲精品自在在线观看| 亚洲国产精品无码久久久不卡 | 亚洲色www永久网站| 亚洲卡一卡2卡三卡4卡无卡三| 免费一级做a爰片性色毛片| 好男人视频在线观看免费看片| 色猫咪免费人成网站在线观看| 精品一区二区三区高清免费观看| 亚洲AV无码国产剧情| 在线观看免费视频资源| 免费无码又爽又刺激一高潮| 日日躁狠狠躁狠狠爱免费视频| 处破女第一次亚洲18分钟| 亚洲色少妇熟女11p| 亚洲成a人片在线观看精品| 久久精品国产亚洲AV麻豆网站| 久久九九亚洲精品| 亚洲乱码中文字幕久久孕妇黑人| 可以免费观看一级毛片黄a| 国产男女性潮高清免费网站| 在线观看免费a∨网站| 好吊妞998视频免费观看在线| 最近最新的免费中文字幕| 午夜国产精品免费观看| 免费A级毛片无码无遮挡内射| 亚洲免费闲人蜜桃| 97在线观看永久免费视频| 久久WWW免费人成一看片| 四虎在线免费视频| 中国在线观看免费高清完整版| 免费看美女裸露无档网站| 国产卡二卡三卡四卡免费网址 | 亚洲人成影院77777| 亚洲午夜精品国产电影在线观看| 亚洲福利电影一区二区?| 亚洲欧洲春色校园另类小说|