SQL SERVER标量表达式的隐式转换

在SQL Server中的数据类型中,存在着优先级的问题.标量表达示的返回结果类型也会根据操作数的类型而定,如1 +'1'=2.而不是'11',因些Int型的优先级比VARCHAR型的优先级要高.所以在表达示的结果隐式转换成Int型.

      同样对于标量函数,如一个表的一列是Int型,表中有两行值为2和3如果对这一列使用AVG函数,则结果是2,而不是2.5.但是如果这一列是Decimal类型的话,那么结果就是2.5.因为结果类型依据操作数据类型.

     如下的一个Case语名

CASE

WHEN <logical_expression1> THEN <int_expression>

WHEN <logical_expression2> THEN <varchar_expression>

WHEN <logical_expression3> THEN <decimal_expression>

END

返回值的类型就为Decimal型,即使第一个表达示满足条件.

 

但是

SELECT

CASE

WHEN 1 > 1 THEN 10

WHEN 1 = 1 THEN ‘abc‘

WHEN 1 < 1 THEN 10.1

END

这个就会出现语法错误,

这时可以使用SQL_VARIANT类型,

SELECT
CASE
WHEN 1 > 1 THEN CAST(10 AS SQL_VARIANT)
WHEN 1 = 1 THEN CAST(‘abc‘ AS SQL_VARIANT)
WHEN 1 < 1 THEN CAST(10. AS SQL_VARIANT)
END;

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。