SQL Server时间粒度系列----第3节旬、月时间粒度详解
IF OBJECT_ID(N'dbo.ufn_PeriodOfMonth', 'FN') IS NOT NULL
BEGIN
DROP FUNCTION dbo.ufn_PeriodOfMonth;
END
GO --==================================
-- 功能: 获得指定日期时间在当前月的旬索引
-- 说明: 从1开始计数,、、3分别对应上、中、下的旬索引。
-- 作者: XXX
-- 创建: yyyy-MM-dd
-- 修改: yyyy-MM-dd XXX 修改内容描述
-- 调用: SET @intPeriods = dbo.ufn_PeriodOfMonth('2008-01-14')
--==================================
CREATE FUNCTION [dbo].[ufn_PeriodOfMonth]
(
@dtmDate DATETIME -- 指定的日期时间
) RETURNS TINYINT
--$Encode$--
AS
BEGIN
--当前月的日索引,从1开始计数,,包括1、、、……、、、、
DECLARE @tintDayOfMonth AS TINYINT;
SET @tintDayOfMonth = DAY(@dtmDate);
-- 旬偏移索引,:上旬,:中旬,:下旬
DECLARE @tintPeriodOffsetIndexID AS INT;
SET @tintPeriodOffsetIndexID = DAY(@dtmDate) / IF @tintDayOfMonth IN (, , , )
BEGIN
SET @tintPeriodOffsetIndexID = @tintPeriodOffsetIndexID - ;
END RETURN @tintPeriodOffsetIndexID + ;
END
GO
IF OBJECT_ID(N'dbo.ufn_DayOfPeriod', 'FN') IS NOT NULL
BEGIN
DROP FUNCTION dbo.ufn_DayOfPeriod;
END
GO --==================================
-- 功能: 获得指定日期时间在当前旬的日索引
-- 说明: 从1开始计数,包括1、2、3、……、8、9、10、11
-- 作者: XXX
-- 创建: yyyy-MM-dd
-- 修改: yyyy-MM-dd XXX 修改内容描述
-- 调用: SET @intPeriods = dbo.ufn_DayOfPeriod('2008-01-14')
--==================================
CREATE FUNCTION [dbo].[ufn_DayOfPeriod]
(
@dtmDate DATETIME -- 指定的日期时间
) RETURNS TINYINT
--$Encode$--
AS
BEGIN
RETURN DAY(@dtmDate) - (dbo.ufn_PeriodOfMonth(@dtmDate) - 1) * 10;
END
GO
IF OBJECT_ID(N'dbo.ufn_Periods', 'FN') IS NOT NULL
BEGIN
DROP FUNCTION dbo.ufn_Periods;
END
GO --==================================
-- 功能: 获得指定日期时间基于基准日期的总旬数(一个整数值)
-- 说明: 如果指定的日期时间为NULL或者小于基准日期“1900-01-01”时,则其值默认基准日期;
-- 结果值为非负整数,从0开始计数。
-- 作者: XXX
-- 创建: yyyy-MM-dd
-- 修改: yyyy-MM-dd XXX 修改内容描述
-- 调用: SET @intPeriods = dbo.ufn_Periods('2008-01-14')
--==================================
CREATE FUNCTION [dbo].[ufn_Periods]
(
@dtmDate DATETIME -- 指定的日期时间
) RETURNS INT
--$Encode$--
AS
BEGIN
SET @dtmDate = dbo.ufn_GetValidDate(@dtmDate); -- 旬偏移索引ID,0:上旬,1:中旬,2:下旬
DECLARE @tintPeriodOffsetIndexID AS INT;
SET @tintPeriodOffsetIndexID = dbo.ufn_PeriodOfMonth(@dtmDate); -- datepart参数也可以为mm或m
RETURN DATEDIFF(MONTH, '1900-01-01', @dtmDate) * 3 + @tintPeriodOffsetIndexID;
END
GO IF OBJECT_ID(N'dbo.ufn_Periods2Date', 'FN') IS NOT NULL
BEGIN
DROP FUNCTION dbo.ufn_Periods2Date;
END
GO --==================================
-- 功能: 获得一个整数值基于基准日期对应的旬基准日期
-- 说明: 如果指定的整数值为NULL或为负整数时,则其值默认为0;
-- 如果指定的整数值大于“9999-12-31”对应的整数值时,则其值默认设置为“9999-12-31”对应的整数值;
-- 结果值为从基准日期开始计数的日期;
-- 旬基准日期是指一个月份中第1天、第11天和第21天对应的日期,比如'2016-02'月份的3个旬基准日期分别为'2016-02-01','2016-02-11','2016-02-21'。
-- 作者: XXX
-- 创建: yyyy-MM-dd
-- 修改: yyyy-MM-dd XXX 修改内容描述
-- 调用: SET @dtmDate = dbo.ufn_Periods2Date(2705) --'1975-02-21'
--==================================
Create FUNCTION dbo.ufn_Periods2Date
(
@intPeriods INT
) RETURNS DATETIME
AS
BEGIN
SET @intPeriods = dbo.ufn_GetValidDateNum(@intPeriods); DECLARE @intMaxPeriods AS INT;
SET @intMaxPeriods = dbo.ufn_Periods('9999-12-31'); IF @intPeriods >= @intMaxPeriods
BEGIN
SET @intPeriods = @intMaxPeriods;
END -- datepart参数也可以为mm或m
-- 以下注释的也可以,不过更接近相对日期+偏移数得到旬基准日期。
--RETURN DATEADD(MONTH, @intPeriods / 3, '1900-01-01') + (@intPeriods - @intPeriods / 3 * 3) * 10;
RETURN DATEADD(DAY, (@intPeriods - @intPeriods / 3 * 3) * 10, DATEADD(MONTH, @intPeriods / 3, '1900-01-01'));
END
GO
DECLARE @dtmDate AS DATETIME;
SET @dtmDate = '2016-01-08'; SELECT dbo.ufn_PeriodOfMonth(@dtmDate) AS 'Period IndexID Of Current Month(1:上旬,2:中旬,3:下旬)'
,dbo.ufn_DayOfPeriod(@dtmDate) AS 'Day IndexID Of Current Period(从1开始结束,包括1、2、3、……、10、11)'; SELECT dbo.ufn_Periods('1900-02-01') AS 'The Total Of Periods Base-on BaseDate"1900-01-01" '
,dbo.ufn_Periods2Date(1) AS 'Period Basedate Mapping 100'
GO
执行后的查询结果如下图:


IF OBJECT_ID(N'dbo.ufn_MonthOfQuarter', N'FN') IS NOT NULL
BEGIN
DROP FUNCTION dbo.ufn_MonthOfQuarter;
END
GO --==================================
-- 功能: 获得一个日期时间的月份在当前季度的月索引
-- 说明: 如果指定的整数值为NULL时,则其值默认设置为基准日期'1900-01-01';
-- 结果值从1开始计数,包括1、2、3。
-- 作者: XXX
-- 创建: yyyy-MM-dd
-- 修改: yyyy-MM-dd XXX 修改内容描述
-- 调用: SET @dtmDate = dbo.ufn_MonthOfQuarter(2008-01-01);
--==================================
CREATE FUNCTION dbo.ufn_MonthOfQuarter
(
@dtmDate DATETIME -- 指定的日期时间
) RETURNS TINYINT
AS
BEGIN
SET @dtmDate = ISNULL(@dtmDate, '1900-01-01');
DECLARE @tintMonthOfQuarter AS TINYINT;
SET @tintMonthOfQuarter = 0; DECLARE @tintMonthOfYear AS TINYINT;
SET @tintMonthOfYear = MONTH(@dtmDate); SET @tintMonthOfQuarter = @tintMonthOfYear - @tintMonthOfYear / 3 * 3; IF @tintMonthOfQuarter = 0
BEGIN
SET @tintMonthOfQuarter = 3;
END RETURN @tintMonthOfQuarter;
END
GO
IF OBJECT_ID(N'dbo.ufn_Months', 'FN') IS NOT NULL
BEGIN
DROP FUNCTION dbo.ufn_Months;
END
GO --==================================
-- 功能: 获得指定日期时间基于基准日期的总月数(一个整数值)
-- 说明: 如果指定的日期时间为NULL或者小于基准日期“1900-01-01”时,则其值默认基准日期
-- 结果值为非负整数,从0开始计数。
-- 作者: XXX
-- 创建: yyyy-MM-dd
-- 修改: yyyy-MM-dd XXX 修改内容描述
-- 调用: SET @intMonths = dbo.ufn_Months('2008-01-14')
--==================================
CREATE FUNCTION dbo.ufn_Months
(
@dtmDate DATETIME
) RETURNS INT
AS
BEGIN
IF @dtmDate IS NULL OR @dtmDate < '1900-01-01'
BEGIN
SET @dtmDate = '1900-01-01';
END -- datepart参数也可以为mm或m
RETURN DATEDIFF(MONTH, '1900-01-01', @dtmDate);
END
GO IF OBJECT_ID(N'dbo.ufn_Months2Date', 'FN') IS NOT NULL
BEGIN
DROP FUNCTION dbo.ufn_Months2Date;
END
GO --==================================
-- 功能: 获得一个整数值基于基准日期对应的月基准日期
-- 说明: 如果指定的整数值为NULL或为负整数时,则其值默认为0;
-- 如果指定的整数值大于“9999-12-31”对应的整数值时,则其值默认设置为“9999-12-31”对应的整数值;
-- 结果值为从基准日期开始计数的日期;
-- 月基准日期是指一个月份中第1天对应的日期,比如'2016-02'月份的月旬基准日期为'2016-02-01'。
-- 作者: XXX
-- 创建: yyyy-MM-dd
-- 修改: yyyy-MM-dd XXX 修改内容描述
-- 调用: SET @dtmDate = dbo.ufn_Months2Date(1296) --'2008-01-01'
--==================================
CREATE FUNCTION dbo.ufn_Months2Date
(
@intMonths INT
) RETURNS DATETIME
AS
BEGIN
IF @intMonths IS NULL OR @intMonths < 0
BEGIN
SET @intMonths = 0;
END DECLARE @intMaxMonths AS INT;
SET @intMaxMonths = dbo.ufn_Months('9999-12-31'); IF @intMonths >= @intMaxMonths
BEGIN
SET @intMonths = @intMaxMonths;
END -- datepart参数也可以为mm或m
RETURN DATEADD(MONTH, @intMonths, '1900-01-01');
END
GO
DECLARE @dtmDate AS DATETIME;
SET @dtmDate = '2016-01-08'; SELECT dbo.ufn_MonthOfQuarter(@dtmDate) AS 'Month IndexID Of Current Quarter(1:第1个月,2:第2个月,3:第3个月)'
,MONTH(@dtmDate) AS 'Month IndexID Of Current Year', DATEPART(MONTH, @dtmDate) AS 'Month IndexID Of Current Year(从1开始结束,包括1、2、3、……、10、12))'; SELECT dbo.ufn_Months(@dtmDate) AS 'The Total Of Months Base-on BaseDate"1900-01-01"'
,dbo.ufn_Months2Date(2) AS 'Month Basedate Mapping 2';
GO


IF OBJECT_ID(N'dbo.ufn_GetValidDate', 'FN') IS NOT NULL
BEGIN
DROP FUNCTION dbo.ufn_GetValidDate;
END
GO --==================================
-- 功能: 获取有效日期
-- 说明: 指定的日期如果为NULL或者小于基准日期'1900-01-01'则默认设置为基准日期'1900-00-01'
-- 作者: XXX
-- 创建: yyyy-MM-dd
-- 修改: yyyy-MM-dd XXX 修改内容描述
-- 调用: SET @dtmDate = dbo.ufn_GetValidDate('2008-01-14')
--==================================
CREATE FUNCTION dbo.ufn_GetValidDate
(
@dtmDate DATETIME -- 指定的日期数
) RETURNS DATETIME
--$Encode$--
BEGIN
IF @dtmDate IS NULL OR @dtmDate < '1900-01-01'
BEGIN
RETURN '1900-01-01';
END RETURN @dtmDate;
END
GO IF OBJECT_ID(N'dbo.ufn_GetValidDateNum', 'FN') IS NOT NULL
BEGIN
DROP FUNCTION dbo.ufn_GetValidDateNum;
END
GO --==================================
-- 功能: 获取有效日期数
-- 说明: 指定的日期数如果为NULL或负数,则默认设置为0
-- 作者: XXX
-- 创建: yyyy-MM-dd
-- 修改: yyyy-MM-dd XXX 修改内容描述
-- 调用: SET @@intDateNum = dbo.ufn_GetValidDateNum(-1)
--==================================
CREATE FUNCTION dbo.ufn_GetValidDateNum
(
@intDateNum INT -- 指定的日期数
) RETURNS INT
--$Encode$--
BEGIN
IF @intDateNum IS NULL OR @intDateNum < 0
BEGIN
RETURN 0;
END RETURN @intDateNum;
END
GO
SELECT dbo.ufn_GetValidDate(NULL) AS 'NULL Default BaseDate"1900-01-01"', dbo.ufn_GetValidDate('1899-12-31') AS 'Less Than BaseDate"1900-01-01" Default BaseDate"1900-01-01"', dbo.ufn_GetValidDate('2016-01-08') AS '2016-01-08'
SELECT dbo.ufn_GetValidDateNum(NULL) AS 'NULL Defult 0', dbo.ufn_GetValidDateNum(-1) AS 'Less Than 0 Defult 0', dbo.ufn_GetValidDateNum(12) AS ''
GO


DECLARE @dtmDate AS DATETIME;
SET @dtmDate = ''; SELECT @dtmDate AS '"" Default BaseDate"1900-01-01"';
SET @dtmDate = 0;
SELECT @dtmDate AS '0 Default BaseDate"1900-01-01"';
SET @dtmDate = @dtmDate + 1;
SELECT @dtmDate AS 'Add operator 等同dateadd(day, num, date)';
SET @dtmDate = -1;
SELECT @dtmDate AS 'substract operator 等同dateadd(day, -1*num, date)';
GO


SQL Server时间粒度系列----第3节旬、月时间粒度详解的更多相关文章
- SQL Server时间粒度系列----第4节季、年时间粒度详解
本文目录列表: 1.SQL Server季时间粒度2.SQL Server年时间粒度 3.总结语 4.参考清单列表 SQL Serve季时间粒度 季时间粒度也即是季度时间粒度.一年每3 ...
- 【目录】sql server 进阶篇系列
随笔分类 - sql server 进阶篇系列 sql server 下载安装标记 摘要: SQL Server 2017 的各版本和支持的功能 https://docs.microsoft.com/ ...
- SQL Server调优系列基础篇
前言 关于SQL Server调优系列是一个庞大的内容体系,非一言两语能够分析清楚,本篇先就在SQL 调优中所最常用的查询计划进行解析,力图做好基础的掌握,夯实基本功!而后再谈谈整体的语句调优. 通过 ...
- SQL Server调优系列基础篇(常用运算符总结——三种物理连接方式剖析)
前言 上一篇我们介绍了如何查看查询计划,本篇将介绍在我们查看的查询计划时的分析技巧,以及几种我们常用的运算符优化技巧,同样侧重基础知识的掌握. 通过本篇可以了解我们平常所写的T-SQL语句,在SQL ...
- SQL Server调优系列基础篇(并行运算总结篇二)
前言 上一篇文章我们介绍了查看查询计划的并行运行方式. 本篇我们接着分析SQL Server的并行运算. 闲言少叙,直接进入本篇的正题. 技术准备 同前几篇一样,基于SQL Server2008R2版 ...
- SQL Server调优系列基础篇(索引运算总结)
前言 上几篇文章我们介绍了如何查看查询计划.常用运算符的介绍.并行运算的方式,有兴趣的可以点击查看. 本篇将分析在SQL Server中,如何利用先有索引项进行查询性能优化,通过了解这些索引项的应用方 ...
- SQL Server调优系列进阶篇(查询语句运行几个指标值监测)
前言 上一篇我们分析了查询优化器的工作方式,其中包括:查询优化器的详细运行步骤.筛选条件分析.索引项优化等信息. 本篇我们分析在我们运行的过程中几个关键指标值的检测. 通过这些指标值来分析语句的运行问 ...
- SQL Server调优系列进阶篇(深入剖析统计信息)
前言 经过前几篇的分析,其实大体已经初窥到SQL Server统计信息的重要性了,所以本篇就要祭出这个神器了. 该篇内容会很长,坐好板凳,瓜子零食之类... 不废话,进正题 技术准备 数据库版本为SQ ...
- SQL Server调优系列进阶篇(如何维护数据库索引)
前言 上一篇我们研究了如何利用索引在数据库里面调优,简要的介绍了索引的原理,更重要的分析了如何选择索引以及索引的利弊项,有兴趣的可以点击查看. 本篇延续上一篇的内容,继续分析索引这块,侧重索引项的日常 ...
随机推荐
- 【腾讯Bugly干货分享】iOS黑客技术大揭秘
本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/5791da152168f2690e72daa4 “8小时内拼工作,8小时外拼成长 ...
- 修改nw.js的exe文件使其请求管理员权限
修改nw.js的exe文件使其请求管理员权限 默认情况下,nw.js发布的nw.exe文件请求的是普通权限,当我们的应用需要访问一些特殊目录或者注册表等,就需要程序启动的时候以管理员权限运行.那么此时 ...
- [ACM_动态规划] 找零种类
问题描述:假设某国的硬币的面值有 1.5.10.50 元四种,输入一个金额 N (正整数,N<=1000),印出符合该金额的硬币组合有多少种. 问题分析: 1.5.10 元组合出 N 元的方法数 ...
- C语言再学习之内存对齐
昨天看Q3的代码,看到有个_INTSAIZEOF的宏,着实晕了一阵.一番google后,终于明白,这个宏的作用是求出变量占用内存空间的大小,先看看_INTSAIZEOF的定义吧: #define _I ...
- vi 卡住怎么办
http://zhidao.baidu.com/question/93283359.html ---------- 我貌似好像按了ctrl+s... 用惯了windows人,会习惯性地按Ctrl+S来 ...
- windows批处理总结
rem echo off 表示之后所有命令行不显示,但命令结果总是会显示的!! 不存在%ROOT_DIR% . %CUR_DIR%的变量 rem @表示命令行不显示当前行,但命令结果总是会显示的!! ...
- swift NSComparator
var cmptr:NSComparator = {(obj1:AnyObject!, obj2:AnyObject!) -> NSComparisonResult in if((obj1[&q ...
- 老学员的学习感悟 --prince2认证有什么用
2007年一月,我加入了荷兰Irdeto(中国)有限公司.刚入公司,我就结识了PRINCE2(受控环境下的项目管理),才知道prince2是英国政府在政府项目中使用的项目管理标准.这一标准早已在欧洲广 ...
- HTML按钮实现!!!文件上传,遮罩层
按钮上传文件: <input type="file" /> file的意思为提交 每个游览器的显示方式都不一样哦 遮罩层: 设两个id <style type ...
- Atitit.异步的实现模式attilax大总结
Atitit.异步的实现模式attilax大总结 1.1. 函数回调(包括的future模式)1 1.2. 事件机制( 包括定时器 listeners 1 1.3. 中断机制1 1.4. 订阅机制 发 ...