mysql varchar vs oracle varchar2

1.错误提示:mysql

     mysql的Data truncation: Data too long for column 'path' at row 1sql

错误缘由:数据库

   1.字段过长而致使出错的,oracle

        2. 多是由于数据库里的表设置的字符集不相同。spa

解决办法:ci

  varchar(10) ——>varchar(20)同步

  alter table `cms_activity_test` convert to character set gbk collate gbk_chinese_ci;(单独修改指定表的字符集)it

 

其余参考:io

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

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

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

SQL> insert into toracle values('北京蒙迪艾尔');
insert into toracle values('北京蒙迪艾尔')
ORA-12899: value too large for column "SCOTT"."TORACLE"."NAME" (actual: 12, maximum: 6)

-- 在oracle中varchar2(6)中插入6个汉字失败

1.varchar2把全部字符都占两字节处理(通常状况下),varchar只对汉字和全角等字符占两字节,数字,英文字符等都是一个字节;2.VARCHAR2把空串等同于null处理,而varchar仍按照空串处理;3.VARCHAR2字符要用几个字节存储,要看数据库使用的字符集,大部分状况下建议使用varchar2类型,能够保证更好的兼容性。
相关文章
相关标签/搜索