前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >PLSQL Developer 中文乱码踩坑记

PLSQL Developer 中文乱码踩坑记

作者头像
叨叨软件测试
发布2020-05-08 14:02:13
4.8K0
发布2020-05-08 14:02:13
举报
文章被收录于专栏:叨叨软件测试叨叨软件测试

环境

操作系统版本:Windows 7 PL/SQL 版本:12.0.1.1814

原因

由于 Oracle 服务器端和客户端字符集编码不一致引起的。

注意点

写在最前面,减少踩坑!!!

网上教程大多未强调这些注意点,像我这样的 Oracle 小白就完美踩坑而过。

  • 设置完环境变量NLS_LANG后,我个人重启 PL/SQl 多次不生效,重启操作系统才生效。
  • 设置客户端和服务器端的字符集后,需要再次UPDATE后,此时SELECT才不是乱码。
  • 执行完 SQL 语句,记得 commit,否则其他会话无法获取最新数据。

解决方法

服务端

检查 Oracle 服务器端字符编码是否一致。

代码语言:sql
复制
-- 检查字符集是否一致 
select userenv('language') from dual;
-- AMERICAN_AMERICA.AL32UTF8


select * from v$nls_parameters a where a.PARAMETER = 'NLS_CHARACTERSET'; 
-- AL32UTF8

客户端

设置客户端字符集

在系统环境变量中,新增变量 NLS_LANG,设置字符集为:AMERICAN_AMERICA.AL32UTF8(服务器端的字符集)。

我个人重启 PL/SQL 不生效,重启系统才生效。

验证是否生效

打开 PL/SQL 工具的:帮助--支持信息--信息 选项卡里进行检查,在“Character Sets”下面,有一项是:“NLS_LANG”, 检查是否与环境变量设置的NLS_LANG一致,一致即生效。

设置字体字符集

打开 PL/SQL 工具的:配置--首选项--用户界面--字体--主字体,设置字体字符集为“西欧语言”,默认为“中文 GB2312”。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-04-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 叨叨软件测试 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 环境
  • 原因
  • 注意点
  • 解决方法
    • 服务端
      • 客户端
        • 设置客户端字符集
        • 设置字体字符集
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档