新手小白,在oracle中varchar2类型,能设置最大值吗

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了新手小白,在oracle中varchar2类型,能设置最大值吗相关的知识,希望对你有一定的参考价值。

查了一下说是变长度存储,比如varchar2(20)存'abc'实际只占3个字符,那么极端一点我把每个字符都设成varchar2(4000)有什么缺点,会影响性能吗

参考技术A 理论上都设成varchar2(4000)不会有什么性能影响,但会有视觉影响,别人看你的代码会吓一跳。本回答被提问者和网友采纳 参考技术B 4000个字节,单字节字符最大4000个
如果是双字节的字符,最大2000个;3字节的1333个追问

创建的时候我设置varchar2(500)和varchar2(4000)有什么区别呢,当存储内容在一百个汉字以内的时候

追答

1,varchar2把所有字符都占两字节处理(一般情况下),varchar只对汉字和全角等字符占两字节,数字,英文字符等都是一个字节;

2,VARCHAR2把空串等同于null处理,而varchar仍按照空串处理;
3,VARCHAR2字符要用几个字节存储,要看数据库使用的字符集。

大部分情况下建议使用varchar2类型,可以保证更好的兼容性。

oracle转Mysql中,varchar2(10)和number应该转换为什么类型? (转)

一. varchar2(10)和number应该转换为什么类型?

oracle转成mysql时:
varchar2(10)可以转成varchar(10)
number则要看oracle中存储的具体是什么类型的数据:
1、如果是整型,那么mysql中,用int即可;
2、如果是带小数位的,那么mysql中可用numeric类型。

注:mysql中没有varchar2(10)和number这两个数据类型

 

二. Mysql varchar VS Oracle varchar2

mysql和oracle做数据同步。其中表的一个字段在mysql中设置为varchar(6),Oracle中为varchar2(6)
但mysql中能正常存放的数据同步到oracle中却抱ORA-12899: value too large for column错误。
这是为什么呢?

mysql中varchar(6)代表可以存放6个汉字,6个字母,或6个数字。
oracle中varchar2(6)代表可以中存放6个字节。即oracle中varchar2的长度代表字节数而不是字符数。
mysql中一个汉字占三个字节,Oracle中一个汉字占两个字节。

 

虽然mysql varchar 和orache varchar2中字段设置相同的长度,但oracle中却存放不下。

http://www.cnblogs.com/yangxia-test/p/4710250.html

以上是关于新手小白,在oracle中varchar2类型,能设置最大值吗的主要内容,如果未能解决你的问题,请参考以下文章

oracle中varchar2类型与integer类型的变量进行运算

oracle中两个varchar2类型的时间怎么进行比较

有啥方法能将oracle中CHAR类型数据中的空格去掉

Oracle中表列由VARCHAR2类型改成CLOB

Oracle LOB类型

Oracle的CLOB大数据字段类型(转)