Step by Step——数据库-char & varchar & nvarchar

1.char & varchar
1)char的长度是不可变的,而varchar的长度是可变的。
定义一个char[10]和varchar[10],如果存进去的是‘csdn’,
→ 长度:char = 10 (字符‘csdn’ + 后面六个空格,;
varchar = 4
取数据的时候,char类型的要用trim()去掉多余的空格,而varchar是不需要的。
2)char的存储方式是,对英文字符(ASCII)占用1个字节,对一个汉字占用两个字节;
而varchar的存储方式是,中英文都占用2个字节,两者的存储数据都非unicode的字符数据。
varchar必char节省空间,但在效率上比char稍微差一些,但性能差距是很小的,可以考虑忽略不计。
因为当修改varchar数据时,可能因为数据长度不同,导致数据迁移(即:多余I/O)。其中,oracle对此多余I/O描述的表达是:“行迁移”(Row Migration)。

2.nvarchar
nvarchar的特性,需要和varchar对比,主要是在对于数据的存储方式上:
1). varchar:按字节存储数据
varchar(6),最多能存储6个字节的数据,比如:“哈哈哈”,“abcdef”…
备注:一个中文字符在数据库里占多少个字节,要看unicode的编码方式,比如:utf8在mysql上占3个字节,sqlserver的Chinese_PRC_CI_AS占2个字节…
2). nvarchar:按字符存储数据
nvarchar(6),最多能存储6个字符/中文数据,比如:“哈哈哈哈哈哈”,“abcdef”…
nvarchar(m)最大存储的实际字节长度=n*m(n跟据编码方式而定),如果nvarchar存储的是英文字符,也是根据编码方式存储n的字节长度。也就是说,如果用nvarchar存储英文字符,会浪费一半以上的存储空间…

PS:
1.varchar (N)中的N指的是该字段最多能存储多少个字符(characters),不是字节数。
2.①varchar2把所有字符都占两字节处理(一般情况下),varchar只对汉字和全角等字符占两字节,数字,英文字符等都是一个字节;
②VARCHAR2把空串等同于null处理,而varchar仍按照空串处理;
③VARCHAR2字符要用几个字节存储,要看数据库使用的字符集,
④大部分情况下建议使用varchar2类型,可以保证更好的兼容性。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值