oracle 关于数据库编码字符集和乱码问题(终)

1.查看数据库服务器端编码:

select * from NLS_DATABASE_PARAMETERS where PARAMETER = 'NLS_CHARACTERSET';

可以看到,数据库服务器端的编码字符集是ZHS16GBK(简体中文 16位GBK编码)

这个参数是数据库建立的时候设置的,一般不会轻易改变。

另外,还有两个参数:

select * from NLS_INSTANCE_PARAMETERS  --实例编码
select * from NLS_SESSION_PARAMETERS --会话编码

NLS_INSTANCE_PARAMETERS  --实例编码(是在系统文件中定义的,修改方式:alter system set)
NLS_SESSION_PARAMETERS --会话编码(默认继承自 NLS_INSTANCE_PARAMETERS  ,在客户端环境变量NLS_LANG可覆盖,或者alter session set 可以对单个会话修改)

2.查看客户端编码:

select userenv('language') from dual

select * from NLS_SESSION_PARAMETERS 

编码字符集默认跟数据库一致。

可在环境变量NLS_LANG设置(对sqlplus生效,对部分连接软件如Dbeaver、PLSQL可能不生效)

作用就是:客户端可以根据这个参数对数据库传输过来的数据进行编码的转换,这是自动进行的;反之,客户端想数据库发送数据时也会有一个转换的过程。

乱码问题的解决方法:

如果客户端(PLSQL,Dbeaver等数据库连接软件)查询乱码,

(1)修改环境变量NLS_LANG值为  select userenv('language') from dual  的查询结果 

(2)查看操作系统的活动代码页(windows是chcp),将NLS_LANG值设置为支持操作系统字符集的字符集。

这篇文章写得比较好:https://www.cnblogs.com/bingo1717/p/7803359.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle 数据库字符集的更改是一个复杂的过程,需要谨慎处理以避免数据丢失或损坏。以下是一个大致的步骤流程: 1. 停止数据库,并以管理员身份登录到操作系统上。 2. 备份数据库,在备份完成后,将备份文件复制到一个安全的位置。 3. 检查当前数据库中的字符集,以确定更改为哪种字符集,并创建一个新的字符集。 4. 使用 Oracle 提供的 Database Migration Assistant for Unicode 工具,检查并解决数据库中的字符集问题。 5. 在解决了字符集问题之后,使用 Oracle 提供的 CSSCAN 工具,扫描数据库中的所有数据,以确保没有任何数据丢失或损坏的风险。 6. 创建一个新的字符集数据库,并将数据库参数设置为适合新字符集的值。 7. 使用 Oracle 提供的 Data Pump 工具,将原有的字符集数据库中的数据导出到一个文件中。 8. 使用 Oracle 提供的 Data Pump 工具,将导出的数据文件中的数据导入到新的字符集数据库中。 9. 调整新数据库中的对象,例如表、索引、视图等,以适应新的字符集。 10. 测试新的数据库,确保所有数据都已成功转换,并且应用程序可以正常访问新的数据库。 需要注意的是,这只是一个大致的步骤流程,具体的操作步骤可能会因为不同的环境和需求而有所不同。在进行这个过程之前,建议先仔细阅读 Oracle 文档,并咨询专业的数据库管理员或顾问的意见。同时,在进行字符集更改之前,应该充分备份数据,并进行必要的测试和验证。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值