char与varchar2

本文详细介绍了数据库中Char与Varchar2两种类型的特性与区别,包括它们的存储方式、长度指定方法及可能产生的问题,如行迁移等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

char表示定长存储,长度不够的用空格补充,最多可存储2000字节
varchar2表示不定长存储,它表示字段定义长度小于等于你的存储数据长度
两者各有优缺点,最多可存储4000字节

据tom同志建议,在任何时候都不要使用char,即使是单字节的字段,原因是因为不论是在表段,还是在索引段中,char都会占用最大的空间.
另外char类型还会带来混乱,其原因与字符串比较的规则有关.

varchar2的缺点:容易引起行迁移的问题.就是指数据在更新时,更新的内容超的块存储容量,必须要提供一个新块才能继续存储,那么字段的数据,就产生分块存储,引起了所谓的行迁移的问题.


varchar2和char类型支持两种指定长度的方法:
     用字节指定:varchar2(12 byte):表示支持最多12字节的数据
     用字符指定:varchar2(12 char):表示支持最多12字符数据.可能是多达40字节的信息.
该定义的默认行为是根据参数:   NLS_LENGTH_SEMANTICS来指定默认值的.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值