oracle mysql中的char,varchar,varchar2的区别
2013-12-13 19:17
381 查看
MySQL中 char是定长的,varchar是变长的。varchar2应该是varchar的升级,似乎只有ORACLE才有,这里不作讨论。 char定长存储,速度快,但是存在一定的空间浪费,适用于字段不是很大,对速度要求高的场合。速度快是因为其在物理上是按定长存储的,这样,就可以根据偏移址一次取出固定长度的字符。 varchar变长存储,所以效率不如char。varchar在存储时,在物理上要先存储该字段的实际长度,然后才是内容。这样读取的时候,就要读取两次,一次读它的长度,然后才是内容。所以它的访问速度会比char慢一些。但它可以节省空间。 由于mysql自身的特点,如果一个数据表存在varchar字段,则表中的char字段将自动转为varchar字段。在这种情况下设置的char是没有意义的。所以要想利用char的高效率,要保证该表中不存在varchar字段;否则,应该设为varchar字段。 Oracle中 区别: 1.CHAR的长度是固定的,而VARCHAR2的长度是可以变化的, 比如,存储字符串“abc",对于CHAR (20),表示你存储的字符将占20个字节(包括17个空字符),而同样的VARCHAR2 (20)则只占用3个字节的长度,20只是最大值,当你存储的字符小于20时,按实际长度存储。 2.CHAR的效率比VARCHAR2的效率稍高。 3.目前VARCHAR是VARCHAR2的同义词。工业标准的VARCHAR类型可以存储空字符串,但是oracle不这样做,尽管它保留以后这样做的权利。Oracle自己开发了一个数据类型VARCHAR2,这个类型不是一个标准的VARCHAR,它将在数据库中varchar列可以存储空字符串的特性改为存储NULL值。如果你想有向后兼容的能力,Oracle建议使用VARCHAR2而不是VARCHAR。 何时该用CHAR,何时该用varchar2? CHAR与VARCHAR2是一对矛盾的统一体,两者是互补的关系. VARCHAR2比CHAR节省空间,在效率上比CHAR会稍微差一些,即要想获得效率,就必须牺牲一定的空间,这也就是我们在数据库设计上常说的‘以空间换效率’。 VARCHAR2虽然比CHAR节省空间,但是如果一个VARCHAR2列经常被修改,而且每次被修改的数据的长度不同,这会引起‘行迁移’(Row Migration)现象,而这造成多余的I/O,是数据库设计和调整中要尽力避免的,在这种情况下用CHAR代替VARCHAR2会更好一些。 |
相关文章推荐
- Dblink Oracle的同义词(synonyms)
- Oracle 11g sys,system 密码忘记设置解决办法
- Oracle索引(B*tree和Bitmap)学习
- Windows 7下完全卸载Oracle 11g数据库
- 浅谈Oracle 重建索引
- oracle存储过程语句
- Oracle中B-TREE索引的深入理解
- Oracle Data Integrator和GoldenGate集成
- Linux c/c++访问Oracle数据库--环境配置
- oracle归档日志--
- win7安装oracle 10g时发生“程序异常终止。发生内部错误”的提示
- ORACLE 几个我忍了他很多年的问题
- Installing Oracle Data Integrator 11.1.1.7 in Oracle Linux 6 u3(64bit)
- 解决oracle 客户端混乱造成OBIEE Client Administration不能连接数据库问题
- Oracle Linux JRE/JDK Installation
- MySqldump数据导入到Oracle过程中的部分方法简记
- oracle+asm创建表空间
- Oracle Database Compression 2 - Advanced/OLTP Compression
- Oracle 物化视图1 - 单表聚合及其快速刷新
- oracle查找重复记录