char varchar nchar nvarchar区别

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字符,根据数据长度自动变化。

在这里插入图片描述

在这里插入图片描述
如上同理;

存储效率上的区别:

  1. char,nchar:定长,速度快,占空间大,需处理

  2. varchar,nvarchar:变长,速度慢,占空间小,无需处理

  3. 速度:这里的速度指的是存取的速度。

  4. 处理:主要是对应用程序来说的,如果使用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变长字符数据则不会以空格填充。
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值