这个问题源于csdn一贴子,后来发现sql server各版本对这个case when else end结果的处理不尽相同。。
CASE语法如下:



















联机文档有文:结果类型:从 result_expressions 和可选 else_result_expression 的类型集中返回优先级最高的类型。
有关详细信息,请参阅 数据类型优先级,如下

































下面准备测试数据及开始测试:











































我以上的测试环境是
Microsoft SQL Server 2008 (SP1) - 10.0.2531.0 (Intel X86) Mar 29 2009 10:27:29 Copyright (c) 1988-2008
Microsoft Corporation Standard Edition on Windows NT 5.2 <X86> (Build 3790: Service Pack 2)
目前发现在不同的版本上,包括小版本号不同,结果均有可能出现不同,不知道这些不符合联机文档描述的版本,是否可以称之为Bug ?
有兴趣的朋友可以测试贴一下你的sql版本的结果。
Microsoft SQL Server 2008 (SP1) - 10.0.2531.0 (Intel X86) Mar 29 2009 10:27:29 Copyright (c) 1988-2008
Microsoft Corporation Standard Edition on Windows NT 5.2 <X86> (Build 3790: Service Pack 2)
目前发现在不同的版本上,包括小版本号不同,结果均有可能出现不同,不知道这些不符合联机文档描述的版本,是否可以称之为Bug ?
有兴趣的朋友可以测试贴一下你的sql版本的结果。