• mysql varchar vs oracle varchar2


    1.错误提示:

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

    错误原因:

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

            2. 可能是因为数据库里的表设置的字符集不相同。

    解决办法:

      varchar(10) ——>varchar(20)

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

    其他参考:

    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中却存放不下

    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类型,可以保证更好的兼容性。
  • 相关阅读:
    SoftWater——SDN+UnderWater系列论文一
    《面向对象程序设计》2018年春学期寒假及博客作业总结
    2017级面向对象程序设计——团队作业3
    2017级面向对象程序设计——团队作业2
    生活
    一文搞懂transform: skew
    如何实现css渐变圆角边框
    使用腾讯云的图片缩略图服务
    谈谈实现瀑布流布局的几种思路
    vue cli 3 那些事儿
  • 原文地址:https://www.cnblogs.com/kxdblog/p/4042331.html
Copyright © 2020-2023  润新知