首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

T-SQL的CASE是否正常("懒惰")评估?

在编程语言中,CASE语句是一种流程控制结构,用于在多个条件之间进行选择。在T-SQL中,CASE语句允许您在一组条件之间进行选择,并根据满足的条件返回特定的值。

在T-SQL中,CASE语句的评估是从上到下进行的,这意味着它会在找到第一个满足条件的表达式后立即返回结果。这种评估方式被称为“懒惰”评估。

例如,以下是一个使用CASE语句的示例:

代码语言:sql
复制
DECLARE @value INT = 2

SELECT
    CASE
        WHEN @value = 1 THEN 'One'
        WHEN @value = 2 THEN 'Two'
        ELSE 'Other'
    END

在这个示例中,因为@value等于2,所以CASE语句将返回'Two',并且不会评估第二个条件。

这种“懒惰”评估的方式可以提高性能,因为它可以避免不必要的条件检查。但是,如果您希望CASE语句完全评估所有条件,并返回最后一个条件的结果,则可以使用“严格”评估方式。

总之,T-SQL的CASE语句是正常的,并且会进行“懒惰”评估,以提高性能。如果您需要CASE语句完全评估所有条件,则可以使用其他方法,例如嵌套IF语句。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

T-SQL学习笔记(索引贴)

没有涉及高级话题 适合有一点T-SQL知识 但想深入了解T-SQL的人看 我觉得例子有很大的借鉴意义 如果对哪篇文章有疑问, 可以在文章下留言 我会尽快回复的 真诚的希望能和朋友们讨论也希望高人多批评 一:简单的语法知识   1:定义变量给变量赋值   2:if和else    3:begin和end    4:两种case语句   5:循环   http://www.cnblogs.com/liulun/articles/1359567.html 二:简单的增 删 改 查和一些相关子句    1:update    2:insert    3:select    4:delete    5:where子句   6:order by子句   7:distinct关键字   8:group by 聚集函数 和 having子句   http://www.cnblogs.com/liulun/articles/1343417.html 三:复杂一点的查询   1:inner join    2:outer join    3:full join cross join    4:union    5:子查询返回单个值   6:子查询返回多个值   7:any some 和 all    8:外部查询和内部查询   9:派生表   http://www.cnblogs.com/liulun/articles/1346166.html 四:约束   1:类型   2:命名   3:主键约束   4:外键约束   5:unique约束   6:check约束   7:default约束   8:禁用约束   9:规则   10:默认值   http://www.cnblogs.com/liulun/articles/1343466.html 五:create drop alter    1:create    2:drop    3:alter    http://www.cnblogs.com/liulun/articles/1343451.html 六:视图   1:创建视图   2:删除和修改视图   3:视图加密   http://www.cnblogs.com/liulun/articles/1373449.html 七:存储过程与用户自定义函数   1:存储过程的简单创建\修改与删除   2:存储过程的输入参数和输出参数   3:用户定义函数   http://www.cnblogs.com/liulun/articles/1362542.html 八:触发器   1:什么是触发器   2:一个简单的触发器   3:针对触发器的相关操作   4:使用触发器记录操作情况   5:视图上的触发器   6:触发器相关函数   http://www.cnblogs.com/liulun/articles/1372964.html 九:全文索引   1:简要介绍全文索引   2:全文索引的相关操作   3:全文目录的相关操作   4:全文查询语法   5:综合实例   http://www.cnblogs.com/liulun/articles/1368655.html 十:游标   1:什么是游标   2:创建一个简单的游标   3:游标的作用域   4:游标的滚动   5:静态游标   6:键驱动的游标   7:动态游标   http://www.cnblogs.com/liulun/articles/1373352.html 附件: T-SQL中常用的函数 http://www.cnblogs.com/liulun/articles/1346212.html T-SQL学习笔记CHM版 https://files.cnblogs.com/liulun/T-SQL学习笔记.rar

01
领券