• 【转】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;
  • 相关阅读:
    复利计算-做汉堡,结对2.0-复利计算再升级
    java集合
    java 封装,继承,多态基础
    购物车
    ajax
    演示
    实验四
    实验三
    构建之法6-7章读后感
    作业调度模拟程序
  • 原文地址:https://www.cnblogs.com/gates/p/4149303.html
Copyright © 2020-2023  润新知