SQL数据类型,了解一下!
string
数据类型 | 字符串的长度 | 最多字符个数 | 存储 |
char(n) | 固定长度 | 8000 | Defined width |
varchar(n) | 可变长度 | 8000 | 2bytes+number of chars |
varchar(max) | 可变长度 | 1073741824 | 2bytes+number of chars |
text | 可变长度 | 2GB | 4bytes+number of chars |
nchar | 固定长度的Unicode | 4000 | Defined width*2 |
nvarchar | 可变长度的Unicode | 4000 | |
ntext | 可变长度的Unicode | 536870912 | |
binary(n) | 固定长度的二进制字符串 | 8000 | |
varbinary | 可变长度的二进制字符串 | 8000 | |
varbinary(max) | 可变长度的二进制字符串 | 2GB | |
image | 可变长度的二进制字符串 | 2GB | |
bit | 允许0、1或null 类似于bool |
varchar、nvarchar和ntext的区别:
而varchar是非Unicode的,所以只有除英文之外的字符串占用字节的实际长度,而不是 n 个字节。(n 必须是一个介于 1 和 8,000 之间的数值。)
nvarchar是Unicode类型的字符串,为了解决字符冲突,但是它存储的时候,每个字符所占的都是字节的存储大小是所输入字符个数的两倍。(n 的值必须介于 1 与 4,000 之间。)
ntext和nvarchar的区别是,nvarchar的限定值在1到4000,而ntext没有限定值,只要在2G的存储空间的之内就可以。
PS:
(Unicode(统一码、万国码、单一码)是计算机科学领域里的一项业界标准,包括字符集、编码方案等。Unicode 是为了解决传统的字符编码方案的局限而产生的,它为每种语言中的每个字符设定了统一并且唯一的二进制编码,以满足跨语言、跨平台进行文本转换、处理的要求。)
Number
数据类型 | 描述 | 存储 |
---|---|---|
tinyint | 允许从 0 到 255 的所有数字。 | 1字节 |
smalint | 允许介于 -32,768 与 32,767 的所有数字。 | 2字节 |
int | 允许介于 -2,147,483,648 与 2,147,483,647 的所有数字。 | 4字节 |
bigint | 允许介于 -9,223,372,036,854,775,808 与 9,223,372,036,854,775,807 之间的所有数字。 | 8字节 |
decimal(p,s) | 固定精度和比例的数字。 允许从 -10^38 +1 到 10^38 -1 之间的数字。 p 参数指示可以存储的最大位数(小数点左侧和右侧)。p 必须是 1 到 38 之间的值。默认是 18。 s 参数指示小数点右侧存储的最大位数。s 必须是 0 到 p 之间的值。默认是 0。 |
5-17字节 |
numeric(p,s) | 固定精度和比例的数字。 允许从 -10^38 +1 到 10^38 -1 之间的数字。 p 参数指示可以存储的最大位数(小数点左侧和右侧)。p 必须是 1 到 38 之间的值。默认是 18。 s 参数指示小数点右侧存储的最大位数。s 必须是 0 到 p 之间的值。默认是 0。 |
5-17字节 |
smallmoney | 介于 -214,748.3648 与 214,748.3647 之间的货币数据。 | 4字节 |
money | 介于 -922,337,203,685,477.5808 与 922,337,203,685,477.5807 之间的货币数据。 | 8字节 |
float(n) | 从 -1.79E + 308 到 1.79E + 308 的浮动精度数字数据。 n 参数指示该字段保存 4 字节还是 8 字节。float(24) 保存 4 字节,而 float(53) 保存 8 字节。n 的默认值是 53。 |
4字节或8个字节 |
real | 从 -3.40E + 38 到 3.40E + 38 的浮动精度数字数据。 | 4字节 |
Date
数据类型 | 描述 | 存储 |
datetime | 从 1753 年 1 月 1 日 到 9999 年 12 月 31 日,精度为 3.33 毫秒。 | 8字节 |
datetime2 | 从 1753 年 1 月 1 日 到 9999 年 12 月 31 日,精度为 100 纳秒。 | 6-8字节 |
smalldatetime | 从 1900 年 1 月 1 日 到 2079 年 6 月 6 日,精度为 1 分钟。 | 4字节 |
date | 仅存储日期。从 0001 年 1 月 1 日 到 9999 年 12 月 31 日。 | 3bytes |
time(7) | 仅存储时间。精度为 100 纳秒。 | 3-5字节 |
datetimeoffset | 与 datetime2 相同,外加时区偏移。 | 8-10字节 |
timetamp | 存储唯一的数字,每当创建或修改某行时,该数字会更新。timestamp 值基于内部时钟,不对应真实时间。每个表只能有一个 timestamp 变量。 |
注:
1. time之后()里的7(默认)代表它的精度,如果你想显示出来的时间为时分秒的话,可以将其设置为0
2. date和datetime都是有起始时间限制的,所以我们在设计数据库的时候需要注意这一点
其他类型
数据类型 | 描述 | |
sql_variant | 存储最多 8,000 字节不同数据类型的数据,除了 text、ntext 以及 timestamp。 | |
uniqueidentifier | 存储全局唯一标识符 (GUID)。 | |
xml | 存储 XML 格式化数据。最多 2GB。 | |
cursor | 存储对用于数据库操作的指针的引用。 | |
table | 存储结果集,供稍后处理。 |