sqlserver序列可以自定义(sql server 自定义分割月功能详解及实现代码)
sqlserver序列可以自定义
sql server 自定义分割月功能详解及实现代码在最近的项目开发过程中,遇到了Sql server自动分割月的功能需求,这里在网上整理下资料.
1、为何出现自定义分割月的需求
今天梳理一个平台的所有函数时,发现了一个自定义分割月函数,也就是指定分割月的开始日索引值(可以从1-31闭区间内的任何一个值)来获取指定日期所对应的分割月数值。这个函数当时是为了解决业务部门获取非标准月(标准月就是从每个月的第一天到最后一天组成一个完成的标准月份)的统计汇总数据的。例如:如果指定分割月的开始日索引值为5则表示某个月的5号到下个月的4号之间作为一个完整的分割月;同样地如果指定分割月的开始日索引值为1则表示标准月等等。
我仔细梳理了这个函数进行了重构简化以及扩展,该自定义分割月函数的实现区别之前写的SQL Server时间粒度系列----第3节旬、月时间粒度详解文章中将一个整数值和月份日期相互转换功能,这个是按照标准月来实现的,虽然思路大致相同,但是并没有针对之前的月份日期和整数值转换函数对来进行扩展而是独立开发新的功能函数。也是为了尽量做到函数功能职责单一性、稳定性、可维护性以及可扩展性。
2、sql server实现自定义分割月功能
自定义分割月功能函数包括两个标量函数:ufn_SegMonths和ufn_SegMonth2Date。ufn_SegMonths获取指定的日期在自定义分割月对应的分割月数值;ufn_SegMonth2Date获取指定一个分割月数值赌对应的月份日期。
sql server 版本的实现T-SQL代码如下:
IF OBJECT_ID(N'[dbo].[ufn_SegMonths]', 'FN') IS NOT NULL BEGIN DROP FUNCTION [dbo].[ufn_SegMonths]; END GO --================================== -- 功能:根据自定义月开始索引值获取指定日期所在的自定义月数。 -- 说明:自定义分割月数 = 年整数值*100 + 当前所在分割月值。 -- 环境:SQL Server 2005+。 -- 调用:SET @intSegMonths = dbo.fn_SegMonths('2008-01-14', 15)。 -- 创建:XXXX-XX-XX XX:XX-XX:XX XXX 创建函数实现。 -- 修改:XXXX-XX-XX XX:XX-XX:XX XXX XXXXXXXX。 --================================== CREATE FUNCTION [dbo].[ufn_SegMonths] ( @dtmDate AS DATETIME -- 日期 ,@tntSegStartIndexOfMonth AS INT = 15 -- 自定义分割月开始索引值(1-31) ) RETURNS INT AS BEGIN IF (@tntSegStartIndexOfMonth = 0 OR @tntSegStartIndexOfMonth >= 32) BEGIN SET @tntSegStartIndexOfMonth = 15; END DECLARE @intYears AS INT ,@tntMonth AS TINYINT ,@sntDay AS SMALLINT; SELECT @intYears = DATEDIFF(YEAR, '1900-01-01', @dtmDate) ,@tntMonth = DATEPART(MONTH, @dtmDate) ,@sntDay = DATEPART(DAY, @dtmDate); IF (@sntDay >= @tntSegStartIndexOfMonth) BEGIN SET @tntMonth = @tntMonth + 1; END IF (@tntMonth > 12) BEGIN SELECT @intYears = @intYears + 1 ,@tntMonth = @tntMonth - 12; END RETURN @intYears * 100 + @tntMonth; END GO IF OBJECT_ID(N'[dbo].[ufn_SegMonths2Date]', 'FN') IS NOT NULL BEGIN DROP FUNCTION [dbo].[ufn_SegMonths2Date]; END GO --================================== -- 功能:获取自定义分割月数对应的自定义分割月日期。 -- 说明:自定义分割月日期 = 自定义分割月数/100对应的年整数日期“组合”当前所在分割月值。 -- 环境:SQL Server 2005+。 -- 调用:SET @dtmSegMonthDate = dbo.fn_SegMonths2Date(11602)。 -- 创建:XXXX-XX-XX XX:XX-XX:XX XXX 创建函数实现。 -- 修改:XXXX-XX-XX XX:XX-XX:XX XXX XXXXXXXX。; --================================== CREATE FUNCTION [dbo].[ufn_SegMonths2Date] ( @intSegMonths AS INT -- 自定义分割月数 ) RETURNS DATETIME AS BEGIN DECLARE @dtmDefaultBasedate AS DATETIME; SET @dtmDefaultBasedate = '1900-01-01'; IF ((@intSegMonths IS NULL) OR (@intSegMonths <= 0)) BEGIN RETURN @dtmDefaultBasedate; END DECLARE @intYears AS INT ,@intMonth AS INT; SELECT @intYears = @intSegMonths / 100 ,@intMonth = @intSegMonths % 100; RETURN DATEADD(MONTH, @intMonth - 1, DATEADD(YEAR, @intYears, @dtmDefaultBasedate)); END GO
3、测试验证效果
针对以上简单的测试代码如下:
DECLARE @dtmStartDate AS DATETIME ,@dtmEndDate AS DATETIME; SELECT @dtmStartDate = '2000-01-01' ,@dtmEndDate = '2016-12-31'; SELECT [T1].* ,[dbo].[ufn_SegMonths2Date]([T1].[SegMonths]) AS SegMonthDate FROM ( SELECT [T].[CDate] ,[dbo].[ufn_SegMonths]([T].[CDate], 28) AS SegMonths FROM ( SELECT DATEADD(DAY, [Num], @dtmStartDate) AS CDate FROM [dbo].[ufn_GetNums](0, DATEDIFF(DAY, @dtmStartDate, @dtmEndDate)) ) AS T WHERE [T].[CDate] BETWEEN '2014-12-01' AND '2016-03-31' ) AS T1 WHERE DATEPART(DAY, [T1].[CDate]) >= 27 GO
效果截图如下:
注意:以上测试代码使用了SQL Server数字辅助表的实现这边文章的内联表值函数ufn_GetNums。
4、总结语
这次是梳理平台的功能性函数所进行的重构简化以及扩展的实现。尽量将日期有关的功能函数梳理出来,便于直接在sql server用户数据库中来使用, 也便于BI仓库中使用。国庆一来已经过去一周,原来打算一周一遍的计划还是延期啦,再次严重检讨自己。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
- 数据库sqlserver定时任务(SQL Server 2005作业设置定时任务)
- 2021-10-24 10:26:05
- sqlserver 怎么排序(SQLserver排序规则基本概念探索)
- sqlserver2014怎么重新激活(解决Windows 10家庭版安装SQL Server 2014出现.net 3.5失败问题)
- sql server查询操作怎么做(sqlserver分页查询处理方法小结)
- sqlserver常用的字符串函数(SqlServer 获取字符串中小写字母的sql语句)
- sqlserver自增字段(SQL Server中identity自增的用法详解)
- sqlserver字符串判断函数(解决sql server保存对象字符串转换成uniqueidentifier失败的问题)
- sqlserver中根据类型分组(SQL SERVER 分组求和sql语句)
- sqlserver存储过程参数默认值(sql server使用临时存储过程实现使用参数添加文件组脚本复用)
- sqlserver使用说明(SQL Server视图的讲解)
- 启动sqlserver代理服务失败(SQL Server代理服务无法启动怎么办)
- sql死锁进程保护(SqlServer查询和Kill进程死锁的语句)
- sqlserver2008收缩数据文件(SQL2008 详解直接将XML存入到SQL中)
- 如何用mysql建立图书管理系统(图书管理系统的sqlserver数据库设计示例)
- sqlserver2008数据库的备份(sql server 2008 压缩备份数据库20g)
- 《祝卿好》台词又土又甜,就喜欢这么直接的恋爱(祝卿好台词又土又甜)
- 大女主 汤唯垂青电视圈,搭档朱亚文出演《大明皇妃孙若微传》(汤唯垂青电视圈)
- 红色代表什么(红色代表什么情感和含义)
- 高中数学题(高中数学题型总结及解题方法)
- 冰岛旅游攻略(冰岛旅游攻略及花费)
- 为什么现在年轻人越来越喜欢买衣服(为什么现在年轻人越来越喜欢买衣服穿)
热门推荐
- 如何调试部署在IIS上的网站
- 云服务器用什么配置(如何选择云服务器 云服务器配置怎么搭配)
- php工作原理及功能(php设计模式之适配器模式原理、用法及注意事项详解)
- visual studio怎么连接数据库(使用Visual Studio Code连接MySql数据库并进行查询)
- python多线程多种方法(详解python多线程之间的同步一)
- docker显示容器的gc日志(解决docker使用GDB,无法进入断点的问题)
- 阿里云服务器慢怎么回事(阿里云服务器进入黑洞应该怎么办?)
- sql server性能调优(SQL Server性能调优之缓存)
- 微信昵称python(Python 微信之获取好友昵称并制作wordcloud的实例)
- 织梦tag标签路径(如何使用织梦tag列表调用自定义字段附加字段?)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9