小编典典

为什么我的 CASE 表达式是不确定的?

all

我正在尝试使用 CASE 表达式创建一个持久计算列:

ALTER TABLE dbo.Calendar ADD PreviousDate AS 
case WHEN [Date]>'20100101' THEN  [Date]
    ELSE NULL
    END PERSISTED

MSDN明确说CASE是确定性的,这里

但是,我收到一个错误:

消息 4936,级别 16,状态 1,第 1 行表“日历”中的计算列“PreviousDate”无法保留,因为该列是不确定的。

当然,我可以创建一个标量 UDF 并将其明确声明为确定性的,但是有没有更简单的方法呢?我已经在获取最新的服务包了。谢谢。


阅读 179

收藏
2022-03-08

共1个答案

小编典典

您需要使用样式转换“20100101”。

源或目标类型为 datetime 或 smalldatetime,其他源或目标类型为字符串,并指定了非确定性样式。

所以,试试这个:

...WHEN [Date] > CONVERT(datetime, '20100101', 112)....

正如我之前回答的那样,从字符串解析日期可能不可靠(主要在评论中)

编辑:

我不会说这是一个错误,但 SQL Server 要求 100% 澄清。yyyymmdd 不是 ISO 并且 SQL Server 解析 yyyy-mm-dd 是不可靠的(请参阅我的答案链接)

2022-03-08