sql-server – SQL Server’MONEY’数据类型是十进制浮点还是二进制浮点?

我找不到拒绝或确认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).

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...