奇怪的 sql server 2008 Power 函数
bigint 的 数据范围是 从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据
但是 , 如果这么写
print CAST(POWER(3, 20) AS BIGINT)
会报这个错误
Msg 232, Level 16, State 3, Line 1 Arithmetic overflow error for type int, value = 3486784401.000000.
尽管 3486784401 小于 bigint的最大值 。
解决方法是 : 改写成
print CAST(POWER(3.0, 20) AS BIGINT)
这样,输出的结果就是
3486784401,
也不报错了
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。