char varchar nchar nvarchar区别
char与varchar的区别
(1) char的长度是不可变的,而varchar的长度是可变的。(也就是说,定义一个char[4]和varchar[4],如果存进去的是‘1’,那么char所占的长度依然为4,除了字符‘1’外,后面跟3个空格,而varchar就立马把长度变为4了)
(2)char的存储方式是,对英文字符(ASCII)占用1个字节,对一个汉字占用两个字节。
(3)varchar的存储方式是,对每个英文字符占用2个字节,汉字也占用2个字节。
仔细观察以上会发现两个类型占用的字节都不一样
nchar: 固定长度,存储Unicode字符。
nvarchar: 可变长度,存储Unicode字符,根据数据长度自动变化。
如上同理;
存储效率上的区别:
-
char,nchar:定长,速度快,占空间大,需处理
-
varchar,nvarchar:变长,速度慢,占空间小,无需处理
-
速度:这里的速度指的是存取的速度。
-
处理:主要是对应用程序来说的,如果使用char,nchar则需要用trim之类的函数把两边的空格去掉。
1.前面加“n”与不加“n”
1.char、varchar、这两个只能用于单字节来存储数据,适合英文,中文会不兼容。我们常用的汉字需要用两个字节来存储,所以就要使用nchar、nvarchar。
2.char、varchar因为是单字节的所以在存储的时候最大数值可以达到8000,而nchar、nvarchar是最大数值4000。
定长和变长的区别:
定长:char,nchar
变长:varchar,nvarchar
定长就是长度固定,没有var前缀的,当要保存的数据长度不够时将自动在其后面填充英文空格,使长度达到相应的长度。
变长就是长度可变,有var前缀的,表示是实际存储空间是动态变化的,比如varchar,nvarchar变长字符数据则不会以空格填充。