在SQL中char、nchar、varchar和nvarchar的区别

首先

  • 1.char:固定长度,存储英文字符,不能包含中文字符。
  • 2.nchar:固定长度,是unicode来存储字符,可以包含中文字符。
  • 3.varchar:可变长度,存储英文字符,不能包含中文字符。按需、按照字节存储,节约空间。
  • 4.nvarchar:可变长度,采用unicode来存储,可以存储中文,相对varchar来说会比varchar大一倍的空间。

区别

1.前面加“n”与不加“n”

  1. char、varchar、这两个只能用于单字节来存储数据,适合英文,中文会不兼容。我们常用的汉字需要用两个字节来存储,所以就要使用nchar、nvarchar。
  2. char、varchar因为是单字节的所以在存储的时候最大数值可以达到8000,而nchar、nvarchar是最大数值4000。

2.char与varchar的区别

  1. char(10)就是给予一个固定的空间,不管存储的内容有没有到达10个字节,都占用10个字节的空间,同时,varchar(10)和nvarchar(10)的最大空间 只能为10字节,如果不到10字节就不占用10字节。

如何使用

1.如果你肯定存储的数据长度,而且不包中文的,可以选择char类型。

2.如果肯定存储的数据长度,但可能包括中文,可以选择nchar类型。

3.如果不确定存储的数据长度,存储只有英文、数字的最好用varchar类型

4.如果不确定存储的数据长度,也有可能有中文,可以选择nvarchar类型

  • 7
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值