我需要帮助为一个视图写一个案例陈述。基表有两列,我将引用它们:'Stage‘和'YesNo’。
如果Stage列是1,YesNo列是1,我需要CASE语句在视图中将其显示为“to”。如果Stage列是1,而YesNo列是0,我需要CASE语句在视图中将其显示为“Yes.‘”。如果Stage列是1,而YesNo列是NULL,则需要使用CASE语句在视图中将其显示为NULL。如果阶段不是1,我需要YesNo列在视图中显示为NULL。
到目前为止,这是我的逻辑,我认为它是正确的,但当我试图运行它时,我得到了一个关于单词'AS‘的语法错误。有什么建议吗?
CASE
WHEN a.Stage = 1 and a.YesorNo = 1 THEN 'No'
ELSE WHEN a.Stage = 1 and a.YesorNo = 0 THEN 'Yes'
END AS NewViewColumn
发布于 2012-12-12 14:56:03
删除ELSE WHEN
,如果省略了ELSE
,那么对于任何不符合剩余逻辑的项,它都将返回null
:
CASE
WHEN a.Stage = 1 and a.YesorNo = 1 THEN 'No'
WHEN a.Stage = 1 and a.YesorNo = 0 THEN 'Yes'
END AS NewViewColumn
或使用:
CASE
WHEN a.Stage = 1 and a.YesorNo = 1 THEN 'No'
WHEN a.Stage = 1 and a.YesorNo = 0 THEN 'Yes'
ELSE 'other'
END AS NewViewColumn
发布于 2012-12-12 14:56:01
CASE
WHEN a.Stage = 1 and a.YesorNo = 1 THEN 'No'
WHEN a.Stage = 1 and a.YesorNo = 0 THEN 'Yes'
ELSE something else -- If you ignored this it will be NULL
END AS NewViewColumn
发布于 2012-12-12 14:55:51
您正在使用ELSE WHEN
,它应该是ELSE
或WHEN .. THEN ..
CASE
WHEN a.Stage = 1 and a.YesorNo = 1 THEN 'No'
ELSE 'Yes'
END AS NewViewColumn
或者:
CASE
WHEN a.Stage = 1 and a.YesorNo = 1 THEN 'No'
WHEN a.Stage = 1 and a.YesorNo = 0 THEN 'Yes'
END AS NewViewColumn
有关更多信息,请查看msdn page on CASE
。
https://stackoverflow.com/questions/13842335
复制