背景:


项目使用oracle数据,在开发环境测试一些正常。项目部署到客户的服务器上后,系统在添加数据的时候报错。输出错误信息,发现是“超出最大长度”的异常。
但是按照数据库的设计,添加的数据应该在允许的数据长度范围内。那么是什么原因导致的呢,因是客户自己按照的oracle数据库,怀疑是部署环境的oracle参数设置和开发环境的不同。
 
过程:
查询oracle的相关参数:select * from nls_database_parameters;开发数据库和部署数据的查询结果如下:
开发数据库:
 
部署数据库:
 
经比较,发现开发库和部署库的 nls_characterset参数的值是不同的。
那么一个汉字和一个英文字母在开发库和部署库中各自占几个字节呢? 我们可以用sql语句查询一下。
select lengthb('金') from dual;

select lengthb('a') from dual;

 
开发库 部署库
经查询一个汉字在开发库中占2个字节,而在部署库中占三个字节。
 
我们可以进一步看一下“金”这个汉字在开发库中和部署库中到底存储成了什么。
使用语句:  select dump('金',1016) from dual;
开发库 部署库
可以看到汉字“金”在开发库中存储为  bd f0 占用2个字节,而在部署库中存储为 e9 87  91 占用3个字节。
 
结论:那么根据以上的信息,我们可以得出结论 当nls_characterset=zhs16gbk 时,一个汉字在oracle中占用2个字节,当nls_characterset=al32utf8时,
一个汉字在oracle中占用3个字节。
 
解决问题:
现在原因基本上已经找到了,那么如何解决。这也就到了我今天想要表达的主题“规避风险”。
网上一搜,发现遇到此问题的同学还是比较多的,下面给出了修改nls_characterset和nls_length_semantics参数的方法,都可以使问题得到解决。
但是修改参数可能带来的后果是非常严重的,风险系数比较高。是采用修改参数的方法是另辟蹊径。我选择了后者。
 
那么是否可以将数据库中的varchar2类型的字段长度扩充进而规避该问题,虽然该方法也有一定的弊端,可以在项目扩充上会有遗留问题,但是在目前来看不失为一个低风险的好方法。
生成扩充脚本的sql语句如下 : 
select 'alter table '||table_name||' modify '||column_name||' VARCHAR2('||data_length*2||');' 
 from cols 
 where data_type = 'VARCHAR2' 

and table_name in (select table_name from tabs where status = 'VALID')

 
生成数据脚本如下:
 
 
参数资料:

客户Oracle数据库在插入数据的时候报超出最大长度的错误(规避风险)的更多相关文章

  1. 向Oracle数据库中插入数据出错:ORA-01036 无效的变量名或数据

    向Oracle数据库中插入数据出错: 经过排查,因为Update数据时没有出错,所以OracleHelper没有问题: 看异常信息提示:无效的变量和数据,应该是SQL语句的问题,调试时所传的实例Use ...

  2. 解决getJdbcTemplate往oracle数据库中插入数据返回主键出错问题

    我们使用Spring中的JdbcDaoSupport往Mysql中插入数据并返回主键代码,我们使用的mysql数据库,主键在数据库中设置为自增长:该类继承自JdbcDaoSupport,所以能直接使用 ...

  3. Mybatis在oracle数据库中插入数据后返回自增值ID

    1.将id设置成自增序列 CREATE OR REPLACE TRIGGER "DATALIB"."TRIG_USER_ADD" BEFORE INSERT O ...

  4. 数据库中插入数据时发生ora-00984错误

    操作Oracle数据库,插入数据时显示:ORA-00984列在此处不允许错误,如下图所示: 出现的原因是由于,在插入字符或字符串型字段时.如果插入的数据是纯数字,则不会有错误:如果出现字符,则会报OR ...

  5. Oracle数据库中插入日期型数据(to_date的用法)(转载)

    往Oracle数据库中插入日期型数据(to_date的用法) INSERT  INTO  FLOOR  VALUES  ( to_date ( '2007-12-20 18:31:34' , 'YYY ...

  6. SQL语句往Oracle数据库中插入日期型数据(to_date的用法)

    Oracle 在操作数据库上相比于其他的 T-sql 有微小的差别,但是在插入时间类型的数据是必须要注意他的 to_date 方法,具体的情况如下: --SQL语句往Oracle数据库中插入日期型数据 ...

  7. Oracle数据库间的数据复制 - SQLPlus中的COPY命令

    Copy命令可以实现不同Oracle数据库间的数据的复制,也是可以实现同一数据库的数据复制,其性能表现和导入/导出相同. 根据9i文档,说Copy命令未来会不支持,但实际上Oracle 11g仍然支持 ...

  8. Oracle数据库四种数据完整性约束

     Oracle数据库四种数据完整性约束 1.实体完整性 同样的数据不能重复插入(1)采取什么措施保证实体完整性?我们可以给表创建主键约束吗,主键保证了数据的唯一性,主键可以保证同一条记录只能插入一次. ...

  9. 将Oracle数据库中的数据写入Excel

    将Oracle数据库中的数据写入Excel 1.准备工作 Oracle数据库"TBYZB_FIELD_PRESSURE"表中数据如图: Excel模板(201512.xls): 2 ...

随机推荐

  1. c - 冒泡/选择排序.

    #include <stdio.h> #define LEN 10 #define TRUE 1 #define FALSE 0 /* 对 10 个数进行排序 */ //选择排序法(值得注 ...

  2. Oracle 分区表中索引失效

    当对分区表进行 一些操作时,会造成索引失效. 当有truncate/drop/exchange 操作分区  时全局索引 会失效. exchange 的临时表没有索引,或者有索引,没有用includin ...

  3. MongoDB自学笔记2---1.2 初识MongoDB

    1.2.1MongoDB简介 MongoDB是一个基于分布式文件存储的数据库.由C++语言编写.旨在为WEB应用提供可扩展的高性能数据存储解决方案. MongoDB是一个介于关系数据库和非关系数据库之 ...

  4. css代码整理、收集

    整理了一下之前用到过的css代码,实现一种效果或许有许多种写法,我这里整理了一下我个人认为兼容性比较好,结构比较简洁的代码……如有写得不对的地方敬请前辈们指点赐教一下,小弟不胜感激!此学习笔记是动态的 ...

  5. centos6.7下 编译安装MySQL5.7

    centos6.7下编译安装MySQL5.7 准备工作 #-----依赖包及MySQL和boost安装包----- #yum包安装: shell> yum -y install gcc-c++ ...

  6. hdu 2016

    Problem Description 输入n(n<100)个数,找出其中最小的数,将它与最前面的数交换后输出这些数.   Input 输入数据有多组,每组占一行,每行的开始是一个整数n,表示这 ...

  7. 这样就算会了PHP么?-3

    关于循环,IF,WHILE.... <?php $month = date("n"); $today = date("j"); if ($today &g ...

  8. 红外 IR 协议原理分析

    1.概述:对多种红外遥控器的信号进行分析,其发出的红外指令中,引导码各不相同,而且后面的控制指令也有较大差别,甚至指令码的位数也不相同,原因是这些红外设计没有遵守相同的红外标准.但是其基本思想是相同的 ...

  9. 【转】深圳FAE,想拿高薪还缺什么?

    原文网址:http://www.eefocus.com/KTHR_IC/blog/11-05/222793_e04c8.html KT老胡您好! 我07年本科毕业在一家医疗民营企业从事了3年多的嵌入式 ...

  10. hdu1540-Tunnel Warfare (线段树区间合并)

    题意:n个村庄,有三种操作,D x 破坏位置为x的村庄,R 修复上一次被破坏的村庄,Q x 输出含有x村庄的连续村庄的最大个数.线段树搞之,区间合并. ls[maxn]为当前节点左面的连续区间,rs[ ...