【SQL】数据类型

版权声明:我的博客我做主! https://blog.csdn.net/lk1822791193/article/details/81475196

                                                    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 存储结果集,供稍后处理。

猜你喜欢

转载自blog.csdn.net/lk1822791193/article/details/81475196