sqlServer利用递归查询--将日期范围转换为日期表

news/2025/1/3 9:05:07/文章来源:https://www.cnblogs.com/lgx5/p/18643307
-- 创建日期表
CREATE TABLE #DateTable
(TheDate DATE NOT NULL PRIMARY KEY
);-- 插入日期序列
DECLARE @StartDate DATE = '2021-01-01', @EndDate DATE = '2021-12-31';WITH DateSequence(Date) AS
(SELECT CAST(@StartDate AS DATE) AS DateUNION ALLSELECT DATEADD(DAY, 1, Date)FROM DateSequenceWHERE DATEADD(DAY, 1, Date) <= @EndDate
)
INSERT INTO #DateTable(TheDate)
SELECT Date
FROM DateSequence
OPTION (MAXRECURSION 0); -- 移除递归限制select * from #DateTable
ALTER FUNCTION [dbo].[fn_GenerateDates]
(@StartDate DATETIME, @EndDate DATETIME
)RETURNS @Output TABLE 
(Value NVARCHAR(4000)
) 
ASBEGININSERT INTO @Output    SELECT TOP (DATEDIFF(Day, @StartDate, @EndDate)+1) CONVERT(VARCHAR(10), YEAR(DATEADD(Day, number, @StartDate))) + '-' + DATENAME(MONTH, DATEADD(Day, number, @StartDate)) + '-' + DATENAME(Day, DATEADD(Day, number, @StartDate)) AS MonthsFROM [master].dbo.spt_values WHERE [type] = N'P' ORDER BY numberRETURN
END

--select Value from [dbo].fn_GenerateDates('2021-02-01','2021-02-15')

--select Value from [dbo].fn_GenerateDates('2020-01-01','2024-12-31')


 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/861784.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

解决U盘不能传输大文件的问题

将“文件系统”改成“NTFS”,默认一般是FAT32,然后点击格式化即可。注意U盘不要有重要数据避免数据丢失

网站打开不稳定,如何排查和解决?

网站打开不稳定可能由多种因素引起,包括服务器性能、网络问题、代码错误等。以下是详细的排查步骤和解决方案,帮助您找到并解决问题:检查服务器性能:CPU和内存使用情况:使用 top 或 htop 命令查看服务器的CPU和内存使用情况。如果资源占用过高,可能导致网站响应缓慢或无法…

服务器配置显示异常,带宽和内存与预期不符

关于您提到的服务器配置显示异常的问题,我们非常理解您的困惑。根据您的描述,您发现服务器的带宽从原来的8M变成了4M,内存也从4G变成了2G。为了帮助您更好地解决这个问题,我们需要进行以下几个步骤的排查和确认。 首先,请确保您登录的是正确的服务器账号和密码。有时由于多…

如何处理服务器端口888突然无法访问的问题

关于您提到的服务器端口888突然无法访问的问题,我们非常理解您的困扰。根据您的描述,宝塔面板因存在致命漏洞,为了保障数据安全,我们在安全组中暂时阻止了888端口。以下是详细的解决方案和建议,帮助您尽快恢复正常访问。 首先,强烈建议您立即更新宝塔面板的安全补丁。这是…

如何解决服务器空间扩容后FTP无法上传文件及宝塔面板容量未更新的问题?

您好,根据您的描述,在升级服务器空间容量后,您遇到了FTP无法上传文件以及宝塔面板显示的容量未更新的问题。以下是详细的解决方案和建议:确认磁盘扩容是否成功:首先,确保服务器提供商确实已经完成了磁盘扩容操作。可以通过服务商的管理控制台或联系技术支持确认扩容状态。…

如何解决云服务器网络访问异常的问题?

您好,根据您的描述,云服务器出现了网络访问异常的情况,严重影响了业务的正常运行。以下是详细的分析和解决方案:确认网络连接状态:使用命令行工具(如ping、traceroute)测试服务器与外部网络的连通性,确定是否存在网络中断或延迟过高的问题。 检查服务器的本地网络配置(…

如何正确开启服务器上的某个端口?

在服务器上正确开启某个特定端口(如465端口)是一项常见但又容易出错的任务。为了确保端口能够顺利打开并正常工作,以下是详细的步骤指南和注意事项:理解端口作用:首先明确要开启的端口用途。例如,465端口主要用于SMTPS协议,即通过SSL加密发送电子邮件。确保该端口确实是…

如何优化数据库查询速度,特别是使用多个CONTAINS条件时?

您好,当您在数据库查询中使用多个CONTAINS条件时,查询速度可能会显著下降。为了优化这种查询,您可以采取以下几种方法: 首先,确保数据库中有适当的索引。索引是提高查询速度的关键。对于包含全文搜索条件的查询,创建全文索引是非常有效的。以MySQL为例,您可以使用以下命…

如何找回宝塔面板的登录网址?

如果您忘记了宝塔面板的登录网址,可以通过以下步骤来找回或重新设置:检查服务器IP地址: 宝塔面板的默认访问地址通常是 http://<服务器IP>:8888 或者 https://<服务器IP>:8888。您可以登录到您的服务器提供商控制台,找到您服务器的公网IP地址。查看宝塔面板安装…

如何解决宝塔面板无法打开的问题?

当您遇到宝塔面板无法打开的情况时,可能是由多种原因引起的。以下是一些常见的排查步骤和解决方案,帮助您快速恢复宝塔面板的正常访问:检查服务器状态: 首先确认服务器是否正常运行。您可以登录到服务器提供商的控制台,查看服务器的状态。如果服务器处于关机或重启状态,请…

服务器流量增大速度太快怎么办?

当您发现服务器流量增大速度过快时,这可能是由多种原因引起的,包括但不限于恶意流量、内容被频繁请求或存储容量不足。为了有效应对这种情况,以下是详细的解决方案和预防措施:分析流量来源:使用流量监控工具(如AWStats、Google Analytics等)详细分析流量来源。找出哪些页…

宝塔面板初始密码错误无法登录怎么办?

当您遇到宝塔面板初始密码错误无法登录的问题时,这可能是由于密码输入错误、配置问题或其他技术原因引起的。为了帮助您尽快恢复正常使用,以下是详细的解决方案和预防措施:核对密码输入:确认输入的用户名和密码是否准确无误。有时可能会因为复制粘贴时带上多余的空格或字符…