SQL Server数值类型可以分为精确数字类型和近似数字类型
精确数字
BIT/SMALLINT/TINYINT/INT/BIGINT
NUMERIC/DECIMAL/SMALLMONEY/MONEY
 
近似数字
FLOAT/REAL
--================================================
类型: bigint
范围: -2^63 (-9,223,372,036,854,775,808) 到 2^63-1 (9,223,372,036,854,775,807)
存储: 8 字节
 
类型: int
范围: -2^31 (-2,147,483,648) 到 2^31-1 (2,147,483,647)
存储: 4 字节
 
类型: smallint
范围: -2^15 (-32,768) 到 2^15-1 (32,767)
存储: 2 字节
 
类型: tinyint
范围: 0 到 255
存储: 1 字节
--================================================
decimal[ (p[ , s] )] 和 numeric[ (p[ , s] )]
固定精度和小数位数。使用最大精度时,有效值从 - 10^38 +1 到 10^38 - 1。
numeric 在功能上等价于 decimal。
默认精度为 18。
p(精度)最多可以存储的十进制数字的总位数,包括小数点左边和右边的位数
s (小数位数)小数点右边可以存储的十进制数字的最大位数。
decimal和numeric的存储空间与精度相关
精度:  1 - 9
存储字节数:5
 
精度:  10-19
存储字节数: 9
 
精度: 20-28
存储字节数: 13
 
精度: 29-38
存储字节数: 17
 
--================================================
货币数据类型
类型: money
范围:  -922,337,203,685,477.5808 到 922,337,203,685,477.5807
存储:  8 字节
 
类型:smallmoney
范围:   -214,748.3648 到 214,748.3647
存储:  4 字节
 
--================================================

浮点数类型
浮点数据为近似值;并非数据类型范围内的所有值都能精确地表示。
类型: real
范围: -3.40E + 38 至 -1.18E - 38、0 以及 1.18E - 38 至 3.40E + 38
存储: 4 字节
类型: float
范围: -1.79E + 308 至 -2.23E - 308、0 以及 2.23E - 308 至 1.79E + 308
float [ ( n ) ] 其中 n 为用于存储 float 数值尾数的位数(以科学记数法表示)
当n在 1-24 区间时,精度为 7,存储空间为 4 字节
当n在 25-53 区间时,精度为 15,存储空间为 8 字节
real相当于float(24)
由于float存放范围内的近似值,不用精确地存储范围内所有可能的值,所有在相同的存储空间内,浮点数可以存放比精确类型范围更大的数据
浮点数在存放和读取时,需要按照一定公式对数据进行转换,因此会有一定的性能损耗

--================================================
在考虑数据类型时,需要考虑以下方面:
1>数据范围和精度
2>类型占用的空间
3>类型是简单类型还是复杂类型,复杂类型会造成额外的消耗
  Simple data types align more directly to native processor types. Complex data types require CPU to review type metadata and to perform branching.

4>类型是定长还是边长,变成类型在数据更新时可能造成数据移动和页拆分
Because a variable-length data type may incur a memcpy when moving, causing additional CPU overhead, use a fixed 8-byte or 4-byte integer assignment if possible.

5>类型的存储形式,近似数值类型在读取和存放时需要额外的转换
Incurs less overhead if the data type is composed of native literals (e.g., int, uint, long, ulong) instead of approximate data types (e.g., float).

6>压缩后的存储空间
A.不同的数值类型压缩比不一样
B.相同的数据值类型的值大小不一样,压缩后存放空间不一样

DataType--数值类型的更多相关文章

  1. .Net判断一个对象是否为数值类型

    这乍一听是个很简单的事,但突然搞起来还真有点无从下手的感觉. 首先当然是通过GetType()方法反射获取其类型信息,然后对其进行分析,但是类型信息Type中并没有简单地给出这么一个属性进行判断. 老 ...

  2. bootstrap-table不分页时对数值类型数据的排序

    html中的代码 <table id="table"></table> sortData.json的数据如下 [ {"name":&qu ...

  3. Python黑帽编程2.2 数值类型

    Python黑帽编程2.2  数值类型 数值类型,说白了就是处理各种各样的数字,Python中的数值类型包括整型.长整型.布尔.双精度浮点.十进制浮点和复数,这些类型在很多方面与传统的C类型有很大的区 ...

  4. MySQL的数值类型,时间

    数值类型 整数型 tinyint  smallint  mediumint  int|integer  bigint 注意: 1, 如何选择数据类型,我们的原则是:够用就行!尽量的选择占用内存小的整型 ...

  5. .Net判断一个对象是否为数值类型探讨总结(高营养含量,含最终代码及跑分)

    前一篇发出来后引发了积极的探讨,起到了抛砖引玉效果,感谢大家参与. 吐槽一下:这个问题比其看起来要难得多得多啊. 大家的讨论最终还是没有一个完全正确的答案,不过我根据讨论结果总结了一个差不多算是最终版 ...

  6. MySQL数据类型——数值类型

    1.1.1 整型 整型 占用字节 范围 范围 tinyint 1 -27~27-1 -128~127 smallint 2 -215~215-1 -32768~32767 mediumint 3 -2 ...

  7. C++中string转化为常用数值类型

    //模板类 用于将string类型转化为 常用数值类型 template <class Type> Type stringToNum(const string& str) { is ...

  8. MySQL(7):数值类型

    1. 数值类型  

  9. 005 Python的数值类型

    005 Python的数值类型 BIF    指的是内置函数,一般不作为变量命名.如 input,while,if,else,float,等等.整型:整数.(python3.0版本把整型和长整型结合在 ...

  10. 使用Convert 类和Parse方法将字符串转换为数值类型

    //用Parse方法将字符串转换为数值类型; long num=Int64.Parse(args[2]) //用别名为Int64c#类型long; long num=long.Parse(args[2 ...

随机推荐

  1. php小白和菜鸟 上班路上可以看的修行博客

    上班地铁 公交上我们不要去追剧 不要去打游戏 不要看看有效性的海量新闻, 我们需要去技术博客里遨游, 下面就推荐点与php有关的可以学习的技术博客; 大部分程序员在自学的道路上不知道走了多少坑,这个视 ...

  2. 【转】JMeter基础之——录制脚本

    Jmeter 是一个非常流行的性能测试工具,虽然与LoadRunner相比有很多不足,比如:它结果分析能力没有LoadRunner详细:很它的优点也有很多: ● 开源,他是一款开源的免费软件,使用它你 ...

  3. 1147 Heaps

    1147 Heaps(30 分) In computer science, a heap is a specialized tree-based data structure that satisfi ...

  4. 1088 Rational Arithmetic

    题意: 给出两个分式(a1/b1 a2/b2),分子.分母的范围为int型,且确保分母不为0.计算两个分数的加减乘除,结果化为最简的形式,即"k a/b",其中若除数为0的话,输出 ...

  5. oracle 11g r2 rac +openfiler 2.99 +centos 6.5+vbox

    继上篇openfiler 2.99安装之后,这一篇讲介绍openfiler的存储配置和oracle 端的服务配置 参考文档:https://www.oracle.com/technetwork/cn/ ...

  6. SDRAM 之时序收敛(学习了特权老师)

    到现在我还是不太理解SDRAM的时序设置,但是可能蒙对了.(呵呵) 开发环境: quartus II 13.0   板子: DE2 EP2C35F672C6N 时序约束step 1:create cl ...

  7. PHP文件操作(三)-文件的写入

    fwrite()  //对文件进行写入 fwrite(file,string,length)file:必选项,需要写入的文件string:必选项,规定要写入文件的字符串length:可选项,规定要写入 ...

  8. python's ninteenth day for me 类的组合,继承。

    组合: 表示一个类的对象作为另一个类对象的属性. 实例化的过程: 1,创建一个对象. 2,__init__ 给对象添加一些属性,对象默认的名字为self. 3,将self所指向的内存空间返回给实例化他 ...

  9. krpano之字幕添加

    字幕是指介绍语音的字幕,字幕随着语音的播放而滚动,随语音暂停而暂停.字幕添加的前提是用之前的方法添加过介绍语音. 原理: 字幕层在溢出隐藏的父元素中向右滑动,当点击声音控制按钮时,字幕位置被固定,再次 ...

  10. Listview使用安卓自带布局实现单选

    安卓提供了一些自带的布局,使用非常简单.直接看代码吧. package com.example.linfeng.myapplication; import android.app.Activity; ...