我找不到拒绝或确认sql Server’MONEY’数据类型是十进制浮点数还是二进制浮点数的任何东西.
在说明中说,MONEY类型范围是从-2 ^ 63到2 ^ 63 – 1,所以这种意味着它应该是一个二进制浮点.
但是在this page,它将MONEY列为“确切”数字.哪种建议MONEY可能是一个十进制浮点数(否则它是如何确切的?或者确切的定义是什么?)
那么如果MONEY是一个十进制浮点,那么MONEY和DECIMAL(19,4)之间有什么区别呢?
解决方法
都不是.如果它是浮点的实现,它将受到与FLOAT和REAL类型相同的不准确之处.见维基百科
Floating Point.
MONEY是fixed point型.
它比DECIMAL(19,4)小一个字节,因为它具有较小的范围(922,337,203,685,477.5808至922,477.5807),而不是(-10 ^ 15 1至10 ^ 15-1).