ITPub博客

首页 > Linux操作系统 > Linux操作系统 > char和varchar2的区别

char和varchar2的区别

原创 Linux操作系统 作者:tolywang 时间:2007-01-18 00:00:00 0 删除 编辑
区别:
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会更好一些。

Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1350683

------------------------------------------------------------

varchar 存放固定长度的字符数据,最长2000个字符。

varchar2 存放可变长字符数据,最大长度为4000字符。,最大長度為4000字符。

varchar 是标准sql提供的数据类型。

varchar2 是oracle提供的独特的数据类型。

oracle保证在任何版本中该数据类型向上和向下兼容,但不保证varchar。

总之,如果想新版本的数据库兼容就不要用varchar,如果想和其他数据库兼容就不要用varchar2。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/35489/viewspace-84491/,如需转载,请注明出处,否则将追究法律责任。

上一篇: DBA需要的技能
请登录后发表评论 登录
全部评论
Oracle , MySQL, SAP IQ, SAP HANA, PostgreSQL, Tableau 技术讨论,希望在这里一起分享知识,讨论技术,畅谈人生 。

注册时间:2007-12-10

  • 博文量
    5595
  • 访问量
    13381945