当前位置:  开发笔记 > 数据库 > 正文

numeric(38,0)作为主键列; 好,坏,谁在乎?

如何解决《numeric(38,0)作为主键列;好,坏,谁在乎?》经验,为你挑选了1个好方法。

在我当前的项目中,我遇到了我们的主数据库脚本.仔细看看它,我注意到我们所有的原始主键都有一个数字类型(38,0) 我们当前正在运行SQL Server 2005作为我们的主要数据库平台.

对于一些上下文,我们支持Oracle和SQL Server作为后端.在Oracle中,我们的主键具有数字类型(38,0).

有人知道这种实施可能产生的副作用和性能影响吗?我一直倡导并实现intbigint作为主键,并且很想知道数字(38,0)是否是更好的选择.



1> Matt Rogish..:

那么,你花更多的数据来存储数字,你永远不会真正达到.

bigint在8字节中达到9,223,372,036,854,775,807

int以4个字节的形式上升到2,147,483,647

一个NUMERIC(38,0)将采取,如果我正在做数学权利,17字节.

没有太大区别,但是:较小的数据类型=内存中的行数较多(或者相同行数的页面数较少)=查找的磁盘I/O较少(索引或数据页搜索).复制,日志页面等相同.

对于SQL Server:INT是IEEE标准,因此CPU更容易比较,因此使用INT与NUMERIC(这是一种压缩十进制格式)可以略微提高性能.(注意在Oracle中,如果当前版本与我长大的旧版本匹配,则所有数据类型都被打包,因此INT内部与NUMERIC(x,0)几乎相同,因此没有性能差异)

因此,在宏观方案中 - 如果您有大量磁盘,RAM和备用I/O,请使用您想要的任何数据类型.如果你想获得更多的表现,请保守一点.

否则在这一点上,我会保持原样.无需改变事物.

推荐阅读
ERIK又
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有