zoukankan      html  css  js  c++  java
  • 【转】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;
  • 相关阅读:
    MySQL 通过多个示例学习索引
    git reset的用法
    git rebase的用法
    学习yii2.0——依赖注入
    学习yii2.0——行为
    学习yii2.0——事件
    学习yii2.0——数据验证
    让Apache和Nginx支持php-fpm模块
    安装python3
    使用php操作memcache
  • 原文地址:https://www.cnblogs.com/gates/p/4149303.html
Copyright © 2011-2022 走看看