第1个回答 推荐于2016-07-03
Char(n)是长度为n个字节的定长的非unicode的字符数据。N为一个介于1到8000之间的值。其存储大小为输入数据的实际字节长度,而不是n个字节。
如果输入的实际字节长度少于n,那么其他位置会被空格填充。在数据存储中英文字母和数字占一个字节,汉字占两个字节。那么char(n)最多可以存储n个英文字母或数字,或者n/2个汉字。 Varchar(n)是长度为n 个字节的可变长度且非 Unicode 的字符数据。n 必须是一个介于1 和8,000 之间的数值。存储大小为输入数据的字节的实际长度,而不是 n 个字节。注意它和char(n)的区别是char(n)是定长的,varchar(n)是变长的。
如果输入的字符的实际字节长度少于n,那么它的长度就是实际输入的字节长度。在数据存储中英文字母和数字占一个字节,汉字占两个字节。
Varchar(n)最多可以存储n个英文字母或数字,或者n/2个汉字。
Char(n)最多可以存储n个英文字母或数字,或者n个汉字。
在数据检索中,一般来说char型字段的数据是最快的,varchar,nvarchar型字段其次。 在所存数据长度不一的情况下,varcahr型字段所占空间最少,char,nvarchar其次。
那么到底在什么样的情况下使用什么样的数据类型那?
如果所存数据长度基本一致,建议使用char型。这样检索速度快,但是提取的时候要注意用trim()函数剔除所存数据两边的空格。 如果所存数据长度差异较大,可以使用varchar或者nvarchar。如果想较好的支持多语言的话,最好使用nvarchar。使用nvarchar可以减少字符转换问题,防止某些情况下乱码的出现。
Char(n) Varchar(n) Nvarchar(n)
N 最大值 8000 8000 4000
数据长度 固定(不足空格填充) 可变(实际数据长度) 可变(实际数据长度)
可存储最多英文(数字) 8000 8000 4000
最多汉字数 4000 4000 4000
英文(数字)所占字节 1 1 2
汉字所占字节 2 2 2
检索速度 快 慢 慢本回答被提问者采纳