oracle如何储存超长汉子_oracle varchar2 字符存储长度问题

Oracle源表中可存放“中文测试”4个汉字,但经过PowerCenter抽取写入同结构目标表后,中文被截断为2个汉字“中文”。

CREATE TABLE 源表

(

A VARCHAR2(4

CHAR)

)

CREATE TABLE 目标表

(

A VARCHAR2(4

CHAR)

)

解决方案:

该问题是由NLS_LENGTH_SEMANTICS=BYTE所致,须将其设置为CHAR。

如:为Integration Service添加

Environment variables:

Name: NLS_LENGTH_SEMANTICS

Value: CHAR

系统环境:

操作系统:Window Server 2003 SP2

中间件:WebSphere Platform 6.1

数据库:Oracle 10.2.0.1.0 字符集:NLS_CHARACTERSET UTF8

Maximo版本号:V7110-890

问题现象:

1、在迁移Maximo数据库配置信息时,在执行类似语句时:

insert into wfassignment@orcl57 select

* from wfassignment t where t.processname=pc_row.processname and

t.processrev=pc_row.processrev;

总是报异常:description

实际长度是106,而目标表中的description字段长度为100,超出最大长度。

2、结果在目标中检查字段:wfassignment.description

varchar2(100) 只能插入约33个中文字加一个英文字;

一个中文字占三个字节,一个英文字占一个字节。

而原数据库wfassignment.description中可以插入100个汉字。

3、用lengthb(description),

length(description)查询字段长度,

在原库中如果字段值都是汉字,则查询结果lengthb是length的三倍,

在新库中同样的字段值,则查询结果长度一样。

问题原因分析:

1、数据库字符集选择的是NLS_CHARACTERSET=UTF8,如果NLS_CHARACTERSET=ZHS16GBK就不会有这种情况;

2、原库中NLS_LENGTH_SEMANTICS=CHAR,新库中NLS_LENGTH_SEMANTICS=BYTE;

3、主要是第2条造成的,如果字符集是UTF8,字段类型VARCHAR2中一个字符占几个字节是由NLS_LENGTH_SEMANTICS参数决定的,

如果是BYTE,则一个字符占一个字节,如果是CHAR,则一个字符占四个字节。

通过下面的语句可以查看实际的data_length长度

select

table_name, column_name, data_type, data_length from cols

4、查看数据库字符集参数的参数表是:v$nls_parameters,与字符集相关参数都在此表中;

也可以用下面的语句查询;

select * from v$parameter where

name = 'nls_length_semantics'

国家字符集:NLS_NCHAR_CHARACTERSET=AL16UTF16

数据库字符集:NLS_CHARACTERSET=AL32UTF8

解决方案:

一、修改目标数据库的"nls_length_semantics"属性值为"CHAR"

1、执行:alter system set

nls_length_semantics = CHAR scope=both;

这种方式修改后重启数据库实例后,再查询时值又是BYTE了;

2、修改文件:{installpath}/oracle/product/10.2.0/admin/orcl/pfile/init.ora.622010124846

添加下面一段:

###########################################

# NLS

###########################################

nls_language="SIMPLIFIED

CHINESE"

nls_length_semantics=CHAR

nls_territory="CHINA"

这种方式修改后重启数据库实例后,再查询时值又是BYTE了;

3、重启服务器电脑,然后查询时值是CHAR了,没有找到原因为什么重启电脑可以了。

二、字段description还是不能插入100个汉字

1、虽然nls_length_semantics已经改为CHAR了,当目标库中表字段description

varchar2(100)还是

不能插入100个汉字

2、查询cols表,发现data_length长度还是100,再看wfassignment.description

字段定义对象,发现数据库类型变为:varchar2(100

byte)

3、alter table wfassignment

modify description VARCHAR2(100); 问题解决;

查询cols表,发现data_length长度是400了,可以插入100个汉字了。

4、执行下面的语句,把生成的脚本保存为一个sql文件,用PL/SQL工具执行,就可以更新所有字符字段:

select 'alter

table '||table_name||' modify '||column_name||'

VARCHAR2('||data_length||');'

from cols

where data_type = 'VARCHAR2' and table_name in

(select

table_name from tabs where status = 'VALID')

三、如果是在Maximo产品中,因为字段wfassignment.description

varchar2(100)都是全文检索字段,

不能够直接修改字段长度,要求删除全文检索索引,处理方法见《删除Maximo中的所有全文检索索引

select * from v$nls_parameters

UPDATE PROPS$ SET NLS_CHARACTERSET='UTF8'

客户端的nls_lang也设为UTF8

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值