[Oracle] 数据库字符集参数设置

项目中遇到跨库数据抽取时,字段定义相同类型相同长度,但是抽取失败的情况。
经过对比发现,在数据库初始安装时该 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单位

你可能感兴趣的:(oracle)