博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【转】SQL SERVER标量表达式的隐式转换
阅读量:5341 次
发布时间:2019-06-15

本文共 749 字,大约阅读时间需要 2 分钟。

在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;

转载于:https://www.cnblogs.com/gates/p/4149303.html

你可能感兴趣的文章
bzoj1048 [HAOI2007]分割矩阵
查看>>
Java中的编码
查看>>
PKUWC2018 5/6
查看>>
As-If-Serial 理解
查看>>
洛谷P1005 矩阵取数游戏
查看>>
在Silverlight中使用HierarchicalDataTemplate为TreeView实现递归树状结构
查看>>
无线通信基础(一):无线网络演进
查看>>
如何在工作中快速成长?阿里资深架构师给工程师的10个简单技巧
查看>>
WebSocket 时时双向数据,前后端(聊天室)
查看>>
关于python中带下划线的变量和函数 的意义
查看>>
linux清空日志文件内容 (转)
查看>>
安卓第十三天笔记-服务(Service)
查看>>
Servlet接收JSP参数乱码问题解决办法
查看>>
【bzoj5016】[Snoi2017]一个简单的询问 莫队算法
查看>>
Ajax : load()
查看>>
MySQL-EXPLAIN执行计划Extra解释
查看>>
Zookeeper概述
查看>>
Zookeeper一致性级别
查看>>
Linux远程登录
查看>>
Linux自己安装redis扩展
查看>>