[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单位

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值