项目中遇到跨库数据抽取时,字段定义相同类型相同长度,但是抽取失败的情况。
经过对比发现,在数据库初始安装时该 NLS_LENGTH_SEMANTIC 参数不一致,现记录下操作步骤:
对于数据库的修改字符集的问题,用于兼容中文字符,一般需要使用两个参数
NLS_LENGTH_SEMANTICS = CHAR NLS_CHARACTERSET = AL32UTF8
查看该参数的值可以查看如下视图:
SELECT * FROM V$NLS_PARAMETERS WHERE PARAMETER IN ('NLS_LENGTH_SEMANTICS','NLS_CHARACTERSET');
修改两个参数时,需要数据库处于OPEN状态
ALTER SYSTEM SET NLS_LENGTH_SEMANTICS = CHAR SCOPE = BOTH;
ALTER DATABASE CHARACTER SET INTERVAL_USE AL32UTF8;
SHUTDOWN IMMEDIATE;
STARTUP;
caution:
一般中文使用两个byte来存放中文,但是为了兼容亚洲其他国家的字符集,所用使用的UTF8,使用了三个byte,按照最新的字符集标准,将UTF8进行扩展为AL32UTF8,用四个byte来存放。
在视图 DBA_TAB_COLUMNS 视图中可以查看 CHAR_LENGTH 设置的是CHAR单位