MSSQL日期按星期几汇总排序

本文介绍了在SQL Server中遇到的按星期几排序的问题,由于默认的datepart函数依赖datefirst参数,导致排序不符合客户需求。作者提供了一个自定义函数fn_get_weekday_cn,确保无论系统语言和datefirst设置如何,星期一始终返回1,解决了跨语言环境的排序需求。此解决方案适用于需要灵活调整星期起始日排序的场景。

之前做一个客户的报表,客户需要按星期几的销售汇总后输出报表,前面做的好好的,后面输出报表的时候,问题就来了,排序有问题

如图第一个是星期二,这个是按中文拼音顺序排的 ,客户要求的是按星期一排第一这样,而且可能会在繁体或者其他语言环境中使用,但是要保证都是星期一排第一这个样子。仔细想一想,如果数据库是英文的,星期几的几个字母排序又不一样,直接用datename函数来作为排序依据肯定不行,那用datepart函数呢?

又有了新的问题,datepart函数,返回的是当前日期是一周的第几天,这个依赖于datefirst系统参数的设定,如果设定数据库环境参数datefirst为7(MSSQL默认),星期一返回的值是2,而星期天返回的则是1。

考虑到可能在不同的语言数据库中使用,所以排除掉了使用case when datename(日期)=N'星期一' then 1 end 这种枚举的方法,因为datename完全可能返回的是其他语言,不可能全部枚举。

         尝试了一番,决定创建一个函数,这个函数的功能是无论系统语言和datefirst参数设定为几,星期一永远返回1,星期天返回7,代码如下

if object_id('fn_get_weekday_cn','FN') is not null drop function fn_get_weekday_cn
go
create function fn_get_weekday_cn(@Date datetime )
 returns int
as 
begin
declare @WeekDay int
set @WeekDay=(DATEPART(WEEKDAY,@Date)-1+@@DATEFIRST)%7
set @WeekDay=case when

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值