[MSSQL]根据日期返回星座

该博客介绍了如何在MSSQL中创建一个函数udf_GetStar,该函数接受日期参数并返回对应的星座。通过一系列的日期比较和UNION ALL操作,函数能够正确判断输入日期所属的星座,并在测试示例中展示出对于不同年份日期的正确返回结果。
 
go

--创建函数(优快云 fredrickhu(小F)提供)

create function udf_GetStar (@ datetime)
RETURNS varchar(100)
-- 返回日期所属星座
BEGIN
RETURN
(
select max(star)
from
(
select '魔羯座' as star,1 as [month],1 as [day]
union all select '水瓶座',1,20
union all select '双鱼座',2,19
union all select '牡羊座',3,21
union all select '金牛座',4,20
union all select '双子座',5,21
union all select '巨蟹座',6,22
union all select '狮子座',7,23
union all select '处女座',8,23
union all select '天秤座',9,23
union all select '天蝎座',10,24
union all select '射手座',11,22
union all select '魔羯座',12,22

) stars

where dateadd(month,[month] - 1,dateadd(year,year(@) - year(0),0)) + [day] - 1 =
(
select max(dateadd(month,[month] - 1,dateadd(year,year(@) - year(0),0)) + [day] - 1)
from (
select '魔羯座
### MSSQL日期格式的使用方法与设置方式 在MSSQL中,日期格式可以通过多种方式进行设置和使用。以下是关于MSSQL日期格式的相关内容: #### 1. 使用`CONVERT`函数进行日期格式化 MSSQL提供了`CONVERT`函数,用于将日期换为特定的字符串格式。该函数的语法如下: ```sql CONVERT(data_type(length), expression, style) ``` 其中,`style`参数定义了日期的输出格式。例如: ```sql SELECT CONVERT(VARCHAR, GETDATE(), 101) AS FormattedDate; -- 输出:MM/DD/YYYY SELECT CONVERT(VARCHAR, GETDATE(), 103) AS FormattedDate; -- 输出:DD/MM/YYYY SELECT CONVERT(VARCHAR, GETDATE(), 120) AS FormattedDate; -- 输出:YYYY-MM-DD HH:MI:SS ``` 以上代码展示了如何通过不同的`style`值来格式化日期[^5]。 #### 2. 使用`FORMAT`函数进行日期格式化 从SQL Server 2012开始,引入了`FORMAT`函数,允许更灵活地格式化日期。其语法如下: ```sql FORMAT(value, format [, culture]) ``` 例如: ```sql SELECT FORMAT(GETDATE(), 'yyyy-MM-dd') AS FormattedDate; -- 输出:YYYY-MM-DD SELECT FORMAT(GETDATE(), 'dd/MM/yyyy') AS FormattedDate; -- 输出:DD/MM/YYYY SELECT FORMAT(GETDATE(), 'MMMM dd, yyyy') AS FormattedDate; -- 输出:完整月份名称 DD, YYYY ``` 需要注意的是,`FORMAT`函数依赖于CLR集成,性能可能不如`CONVERT`函数[^6]。 #### 3. 设置会话级别的日期格式 可以使用`SET DATEFORMAT`命令来设置当前会话的日期格式。此命令影响日期字符串解析的顺序(如`MDY`、`DMY`等)。例如: ```sql SET DATEFORMAT MDY; -- 设置日期格式为月/日/年 SELECT CAST('01/02/2023' AS DATE) AS ParsedDate; -- 解析为2023-01-02 SET DATEFORMAT DMY; -- 设置日期格式为日/月/年 SELECT CAST('01/02/2023' AS DATE) AS ParsedDate; -- 解析为2023-02-01 ``` 注意,`SET DATEFORMAT`仅影响日期字符串的解析,而不影响日期的显示格式[^7]。 #### 4. 导入或导出数据时的日期格式处理 当使用`BULK INSERT`或`OPENROWSET`导入外部文件中的日期数据时,确保文件中的日期格式与MSSQL的解析规则兼容。如果需要自定义格式,可以在导入后通过`CONVERT`或`FORMAT`函数进行换。例如: ```sql BULK INSERT mytable FROM 'C:\data\dates.txt' WITH ( FIELDTERMINATOR = ',', ROWTERMINATOR = '\n' ); -- 假设文件中的日期格式为DD/MM/YYYY,可以使用以下查询进行换 SELECT CONVERT(DATE, date_column, 103) AS ConvertedDate FROM mytable; ``` ### 示例代码 以下是一个完整的示例,展示如何在MSSQL中使用`CONVERT`和`FORMAT`函数: ```sql -- 使用CONVERT函数 SELECT GETDATE() AS CurrentDateTime, CONVERT(VARCHAR, GETDATE(), 101) AS MMDDYYYY, CONVERT(VARCHAR, GETDATE(), 103) AS DDMMYYYY, CONVERT(VARCHAR, GETDATE(), 120) AS YYYYMMDDHHMMSS; -- 使用FORMAT函数 SELECT GETDATE() AS CurrentDateTime, FORMAT(GETDATE(), 'yyyy-MM-dd') AS YYYYMMDD, FORMAT(GETDATE(), 'dd/MM/yyyy') AS DDMMYYYY, FORMAT(GETDATE(), 'MMMM dd, yyyy') AS FullDate; ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

厦门德仔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值