本文介绍了IIF(...) 不是公认的内置函数的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试在 Microsoft SQL Server 2008 R2 中使用它:

I'm trying to use this in Microsoft SQL Server 2008 R2:

SET @SomeVar = @SomeOtherVar +
  IIF(@SomeBool, 'value when true', 'value when false')

但我收到一个错误:

IIF(...) 不是可识别的内置函数名

仅是 IIF()与更高版本兼容?

Is IIF() only compatible with a later version?

有我可以使用的替代功能吗?

Is there an alternate function I can use?

推荐答案

IIF 来自 SQL 2012.在此之前,您可以使用 CASE:

IIF comes from SQL 2012. Before then, you can use CASE:

SET @SomeVar = @SomeOtherVar + CASE
 WHEN @SomeBool
 THEN 'value when true'
 ELSE 'value when false'
END

这篇关于IIF(...) 不是公认的内置函数的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

10-10 21:58