SQL Server中char、varchar、nvarchar的区别

版权声明:未经本人同意不得转载! https://blog.csdn.net/Hellen0708/article/details/82744145

- CHAR

char是定长的,比如设置数据类型为char(10),输入’ABC’,后面会有7个空字符,当读取数据时,就要用到trim()。而当字符数超出规定的数据类型长度,则截取超出的字符。

- VARCHAR

varchar长度为n个字节的可变长度,n必须是介于1-8000之间的数值。varchar存储大小为输入字符的实际长度。规定的数据类型长度为最大值,字符长度也可以为零。

- CHAR与VARCHAR

如果一个字段的值是固定不变的,例如:性别。这样的字段,使用CHAR效率更高,由于是定长的,所以检索速度很快。而如果不是固定长度的字段使用CHAR就是使用空间换取时间效率。而VARCHAR的优势是空间效率高,可以随着字段的长短而改变长度。由于它的长度是不确定的,所以检索速度是不如CHAR快的。至于使用哪个数据类型要根据数据需求进行分析。

- NCHAR、NVARCHAR、NTEXT

这三种数据类型前面都有N,它表示储存的是Unicode数据类型的字符。非Unicode数据类型的字符,英文字符需要一个字节存储,而中文字符需要2个节存储,而中英文混合时就会比较混乱。而Unicode类型的字符集就是为了解决这种混乱,它所有的字符都用2个字节存储。NCHAR和NVARCHAR长度是在1-4000之间。而CHAR、VARCHAR长度为1-8000个英文、4000个汉字。所以,一般中文字符使用NCHAR、NVARCHAR,而纯英文或数字使用CHAR、VARCHAR.

猜你喜欢

转载自blog.csdn.net/Hellen0708/article/details/82744145