SQL Server時間粒度系列----第4節季、年時間粒度詳解

来源:http://www.cnblogs.com/dzy863/archive/2016/01/11/5120465.html
-Advertisement-
Play Games

本文目錄列表:1、SQL Server季時間粒度2、SQL Server年時間粒度3、總結語4、參考清單列表SQL Serve季時間粒度 季時間粒度也即是季度時間粒度。一年每3個月是一個季,一年共4季,1月到3月是第1季、4月到6月是第2個季、依次順延。季也是日期時間範圍的,我們也會引入季基準日期....


本文目錄列表: 1、SQL Server季時間粒度
2、SQL Server年時間粒度 3、總結語 4、參考清單列表   SQL Serve季時間粒度       季時間粒度也即是季度時間粒度。一年每3個月是一個季,一年共4季,1月到3月是第1季、4月到6月是第2個季、依次順延。季也是日期時間範圍的,我們也會引入季基準日期,也就是每個季度的第一天。以下提供季基準日期和整數相互轉換的功能的實現,還有獲取指定日期時間所在當前年內的季索引,從1開始計數,包括1、2、3、4。       提供季基準日期和整數相互轉換的功能函數,T-SQL代碼如下:
 1 IF OBJECT_ID(N'dbo.ufn_Quarters', 'FN') IS NOT NULL
 2 BEGIN
 3     DROP FUNCTION dbo.ufn_Quarters;
 4 END
 5 GO
 6  
 7 --==================================
 8 -- 功能: 獲得指定日期時間基於基準日期的總季數(一個整數值)
 9 -- 說明: 如果指定的日期時間為NULL或者小於基準日期“1900-01-01”時,則其值預設基準日期
10 --       結果值為非負整數,從0開始計數。
11 -- 作者: XXX
12 -- 創建: yyyy-MM-dd
13 -- 修改: yyyy-MM-dd XXX 修改內容描述
14 -- 調用: SET @sintQuarters = dbo.ufn_Quarters('2008-01-14')
15 --==================================
16 CREATE FUNCTION dbo.ufn_Quarters
17 (
18     @dtmDate DATETIME                    -- 指定的日期時間
19 ) RETURNS SMALLINT
20     --$Encode$--
21 AS
22 BEGIN
23     SET @dtmDate = dbo.ufn_GetValidDate(@dtmDate);
24  
25     -- datepart參數也可以為qq或q
26     RETURN DATEDIFF(QUARTER, '1900-01-01', @dtmDate);
27 END
28 GO
29  
30 IF OBJECT_ID(N'dbo.ufn_Quarters2Date', 'FN') IS NOT NULL
31 BEGIN
32     DROP FUNCTION dbo.ufn_Quarters2Date;
33 END
34 GO
35  
36 --==================================
37 -- 功能: 獲得一個整數值基於基準日期對應的季基準日期
38 -- 說明: 如果指定的整數值為NULL或為負整數時,則其值預設為0;
39 --       如果指定的整數值大於“9999-12-31”對應的整數值時,則其值預設設置為“9999-12-31”對應的整數值;
40 --       結果值為從基準日期開始計數的日期;
41 --       季基準日期是指所在季度的第一個月份中第1天對應的日期,比如'2016-06-08'月份的姐旬基準日期為'2016-04-01'。
42 -- 作者: XXX
43 -- 創建: yyyy-MM-dd
44 -- 修改: yyyy-MM-dd XXX 修改內容描述
45 -- 調用: SET @dtmDate = dbo.ufn_Quarters2Date(300) --'1975-02-21'
46 --==================================
47 CREATE FUNCTION dbo.ufn_Quarters2Date 
48 (
49     @sintQuarters SMALLINT
50 ) RETURNS DATETIME
51     --$Encode$--
52 AS
53 BEGIN
54     SET @sintQuarters = dbo.ufn_GetValidDateNum(@sintQuarters);
55  
56     DECLARE @sintMaxQuarters AS SMALLINT;
57     SET @sintMaxQuarters = dbo.ufn_Quarters('9999-12-31');
58  
59     IF @sintQuarters >= @sintMaxQuarters
60     BEGIN
61         SET @sintQuarters = @sintMaxQuarters;
62     END
63  
64     -- datepart參數也可以為qq或q
65     RETURN DATEADD(QUARTER, @sintQuarters, '1900-01-01')
66 END
67 GO

 

       獲取指定日期時間在當前年的旬索引的功能函數,T-SQL代碼如下:
 1 IF OBJECT_ID(N'dbo.ufn_QuarterOfYear', 'FN') IS NOT NULL
 2 BEGIN
 3     DROP FUNCTION dbo.ufn_QuarterOfYear;
 4 END
 5 GO
 6 
 7 --==================================
 8 -- 功能: 獲取指定的日期時間所在當前年內的旬索引
 9 -- 說明: 結果從1開始計數,1、2、3、4分別表示第1季度、第2季度、第3季度、第4季度。
10 -- 作者: XXX
11 -- 創建: yyyy-MM-dd
12 -- 修改: yyyy-MM-dd XXX 修改內容描述
13 -- 調用: SET @tintQuarterOfYear = dbo.ufn_QuarterOfYear('2016-01-11');
14 --==================================
15 CREATE FUNCTION dbo.ufn_QuarterOfYear
16 (
17     @dtmDate DATETIME                --指定的日期時間
18 ) RETURNS TINYINT
19     --$Encode$--
20 AS
21 BEGIN
22     -- datepart參數也可以為qq或q
23     RETURN DATEPART(QUARTER, @dtmDate);
24 END
25 GO

 

    測試以上三個功能函數的效果,T-SQL代碼如下:
 1 DECLARE @dtmDate AS DATETIME;
 2 SET @dtmDate = '2016-01-11';
 3  
 4 SELECT @dtmDate AS 'The Current Date'
 5     ,dbo.ufn_Quarters(@dtmDate) AS 'The Total Of Quarters Base-on Basedate"1900-01-01"'
 6     ,dbo.ufn_Quarters2Date(dbo.ufn_Quarters(@dtmDate)) AS 'Quarter Basedate Mapping'
 7     ,dbo.ufn_QuarterOfYear(@dtmDate) AS 'The Quarter IndexID,Starting With 1';
 8  
 9 SET @dtmDate = '2016-09-11';
10  
11 SELECT @dtmDate AS 'The Current Date'
12     ,dbo.ufn_Quarters(@dtmDate) AS 'The Total Of Quarters Base-on Basedate"1900-01-01"'
13     ,dbo.ufn_Quarters2Date(dbo.ufn_Quarters(@dtmDate)) AS 'Quarter Basedate Mapping'
14     ,dbo.ufn_QuarterOfYear(@dtmDate) AS 'The Quarter IndexID,Starting With 1'
15 GO
16   

    執行後的查詢結果如下圖

  SQL Server年時間粒度       年時間粒度很容易理解的,在SQL Server提供的有關日期時間數據類型中,能夠支持日期部分的最大範圍區間是[0000-01-01,9999-12-31],那麼指定日期在這個日期範圍的年索引是從1開始,包括1、2、3、……、9998、9999。年基準日期也即是當前年的第一天,比如"2016-01-11"所在當前年的年基準日期是”2016-01-01“,提供年基準日期和整數相互轉換的功能函數實現。          獲取指定的日期時間所在日期的年索引的功能函數,T-SQL代碼如下:
 1 IF OBJECT_ID(N'dbo.ufn_YearOfDate', 'FN') IS NOT NULL
 2 BEGIN
 3     DROP FUNCTION dbo.ufn_YearOfDate;
 4 END
 5 GO
 6  
 7 --==================================
 8 -- 功能: 獲取指定的日期時間所在日期內的年索引
 9 -- 說明: 結果從1開始計數,1、2、3、……、9998、9999。
10 -- 作者: XXX
11 -- 創建: yyyy-MM-dd
12 -- 修改: yyyy-MM-dd XXX 修改內容描述
13 -- 調用: SET @sintYearOfDate = dbo.ufn_YearsOfDate('2016-01-11');
14 --==================================
15 CREATE FUNCTION dbo.ufn_YearOfDate
16 (
17     @dtmDate DATETIME                --指定的日期時間
18 ) RETURNS SMALLINT
19     --$Encode$--
20 AS
21 BEGIN
22     RETURN YEAR(@dtmDate);
23 END
24 GO
25  

 

    提供年基準日期和整數相互轉換的功能函數,T-SQL代碼如下:
 1 IF OBJECT_ID(N'dbo.ufn_Years', 'FN') IS NOT NULL
 2 BEGIN
 3     DROP FUNCTION dbo.ufn_Years;
 4 END
 5 GO
 6  
 7 --==================================
 8 -- 功能: 獲得指定日期時間基於基準日期的總年數(一個整數值)
 9 -- 說明: 如果指定的日期時間為NULL或者小於基準日期“1900-01-01”時,則其值預設基準日期
10 --       結果值為非負整數,從0開始計數。
11 -- 作者: XXX
12 -- 創建: yyyy-MM-dd
13 -- 修改: yyyy-MM-dd XXX 修改內容描述
14 -- 調用: SET @intMonths = dbo.ufn_Years('2008-01-14')
15 --==================================
16 CREATE FUNCTION dbo.ufn_Years 
17 (
18     @dtmDate DATETIME            -- 指定的日期時間
19 ) RETURNS SMALLINT
20     --$Encode$--
21 AS
22 BEGIN
23     SET @dtmDate = dbo.ufn_GetValidDate(@dtmDate);
24  
25     -- datepart參數也可以為yy或yyyy
26     RETURN DATEDIFF(YEAR, '1900-01-01', @dtmDate)
27 END
28 GO
29  
30 IF OBJECT_ID(N'dbo.ufn_Years2Date', 'FN') IS NOT NULL
31 BEGIN
32     DROP FUNCTION dbo.ufn_Years2Date;
33 END
34 GO
35  
36 --==================================
37 -- 功能: 獲得一個整數值基於基準日期對應的年基準日期
38 -- 說明: 如果指定的整數值為NULL或為負整數時,則其值預設為0;
39 --       如果指定的整數值大於“9999-12-31”對應的整數值時,則其值預設設置為“9999-12-31”對應的整數值;
40 --       結果值為從基準日期開始計數的日期;
41 --       年基準日期是指所在年的第一個月份中第1天對應的日期,比如'2016-06-08'月份的姐旬基準日期為'2016-01-01'。
42 -- 作者: XXX
43 -- 創建: yyyy-MM-dd
44 -- 修改: yyyy-MM-dd XXX 修改內容描述
45 -- 調用: SET @dtmDate = dbo.ufn_Years2Date(300) --'1975-02-21'
46 --==================================
47 CREATE FUNCTION dbo.ufn_Years2Date
48 (
49     @sintYears SMALLINT
50 ) RETURNS DATETIME
51     --$Encode$--
52 AS
53 BEGIN
54     SET @sintYears = dbo.ufn_GetValidDateNum(@sintYears);
55  
56     DECLARE @sintMaxYears AS SMALLINT;
57     SET @sintMaxYears = dbo.ufn_Years('9999-12-31');
58  
59     IF @sintYears >= @sintMaxYears
60     BEGIN
61         SET @sintYears = @sintMaxYears;
62     END
63  
64     -- datepart參數也可以為yy或yyyy
65     RETURN DATEADD(YEAR, @sintYears, '1900-01-01')
66 END
67 GO

    

    測試以上3個功能函數的效果,T-SQL代碼如下:
 1 DECLARE @dtmDate AS DATETIME;
 2 SET @dtmDate = '2016-01-11';
 3  
 4 SELECT @dtmDate AS 'The Current Date'
 5     ,dbo.ufn_Years(@dtmDate) AS 'The Total Of Years Base-on Basedate"1900-01-01"'
 6     ,dbo.ufn_Years2Date(dbo.ufn_Years(@dtmDate)) AS 'Year Basedate Mapping'
 7     ,dbo.ufn_YearOfDate(@dtmDate) AS 'The Year IndexID,Starting With 1';
 8  
 9 SET @dtmDate = '2016-09-11';
10  
11 SELECT @dtmDate AS 'The Current Date'
12     ,dbo.ufn_Years(@dtmDate) AS 'The Total Of Years Base-on Basedate"1900-01-01"'
13     ,dbo.ufn_Years2Date(dbo.ufn_Years(@dtmDate)) AS 'Year Basedate Mapping'
14     ,dbo.ufn_YearOfDate(@dtmDate) AS 'The Year IndexID,Starting With 1';
15 GO

 

     執行後的查詢結果如下圖

  總結語          本文主要提供了季和年這兩個時間粒度的講解,也分別提供的其基準日期和整數相互轉換的功能實現,還有各自有關的索引功能函數。之前的博文也有獲取比如旬內日索引、月內日索引、月內旬索引等等的相關功能函數,這些都不是基於基準日期”1900-01-01“,都是在SQL Server能支持的最大的日期部分的範圍區間【0001-01-01,9999-12-31】的。          以上有關季和年有關的功能函數,使用了ufn_GetValidDate和ufn_GetValidDateNum這兩個通用同能函數,可以參考SQL Server時間粒度系列----第3節旬、月時間粒度詳解,裡面有具體的實現。   參考清單列表

1、https://msdn.microsoft.com/zh-cn/library/ms186819(v=sql.90).aspx

2、https://msdn.microsoft.com/zh-cn/library/ms189794(v=sql.90).aspx

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 原文:http://www.cnblogs.com/FreeDong/archive/2013/07/31/3227638.html一、委托調用方式1. 最原始版本:delegate string PlusStringHandle(string x, string y);class Program{...
  • 首先是存儲過程,只取出我需要的那段數據,如果頁數超過數據總數,自動返回最後一頁的紀錄:set ANSI_NULLS ONset QUOTED_IDENTIFIER ONGO-- =============================================-- Author: Clear...
  • //c datetime 格式化DateTime dt = DateTime.Now;Label1.Text = dt.ToString();//2005-11-5 13:21:25Label2.Text = dt.ToFileTime().ToString();//1277564168599128...
  • 各位好,終於講到自定義Panel了。當系統自帶的幾個Panel比如Gird,StackPanel,RelativePanel不能滿足我們的特定要求時(其實不常見啦),自定義Panel就顯得非常必要,而且因為是針對性的處理,效果也會非常好。更何況自定義Panel其實並不複雜,今天俺們就來學習一下。.....
  • 很久之前寫過一篇介紹Options的文章,2016年再打開發現很多變化。增加了新類,增加OptionMonitor相關的類。今天就對於這個現在所謂的新版本進行介紹。老版本的傳送門([Asp.net 5] Options-配置文件之後昂的配置)。首先上一個圖:*綠線是繼承關係,藍線是關聯關係。我們把上...
  • 目前最常見的兩種軟體安裝方式:1.dpkg2.rpm1.dpkg最早是由Debian Linux社群開發出來的,通過dpkg,Debian提供的軟體就可以簡單的安裝,同時還能提供安裝後的軟體信息,實在非常不錯,只要是衍生與Debian的其他的Linux發行版也大多使用dpkg這個機制來管理軟體。包括...
  • 辦公室的電腦已經有好幾台自動升級到windows10了。由於用著很不習慣都要求改回windows7.升級了就不支持退回去,只能是全部刪除重新安裝了,很是麻煩。但是也沒有看到哪裡有可以關閉自動升級的地方今天看到一個文章是說微軟有提供一個方法就是修改註冊表的。 具體步驟如下: 1、打開註冊表編輯器 .....
  • 通過ffplay實現攝像頭preview硬體平臺:Jetson TK1 開發板(NVIDIA Tegra K1 Mobile Processor 32bit),寧波舜宇光電SP103A(OV16825)模組軟體平臺:Ubuntu/Linaro 4.8.2-16ubuntu4(Linux versio...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...