PL/SQL Developer 中文字段显示乱码

时间:2022-03-27 08:14:24

PL/SQL Developer 中文字段显示乱码

  • 数据库学习笔记(2)

在数据表中插入一条数据,可以正常出入,但是当查询显示的时候,中文字符无法显示出来,而是显示的问号(???)
如执行以下代码:

create table student(
sid number(10),
sname varchar2(20),
constraint student_sid_un unique(sid)
)

insert into student values(1,'张三');

执行成功后, 输入select * from student 语句查询时,1能正常显示,SNAME 列的‘张三’显示为‘???’。

产生原因:

是由于数据库的编码格式和PL/SQL Developer的编码格式不统一造成的

解决方法:

(1)修改PL/SQL Developer 的编码格式:

在windows,环境变量设置中,创建一个名为“NLS_LANG”的系统环境变量,设置其值为“SIMPLIFIED CHINESE_CHINA.ZHS16GBK”,
然后重新启动 pl/sql developer,这样检索出来的中文内容就不会是乱码了。如果想转换为UTF8字符集,可以赋予“NLS_LANG”为 “AMERICAN_AMERICA.UTF8”,然后重新启动 pl/sql developer。其它字符集设置也是一样的。(我是使用的这种方法,修改后重启pl/sql developer,能正常显示中文字符)

(2)查看和修改oracle数据库字符集:

select userenv('language') from dual;
查询结果:

SIMPLIFIED CHINESE_CHINA.AL32UTF8

–修改oracle数据库字符集:(在cmd命令窗口中输入sqlplus)

sql> conn / as sysdba;
sql> shutdown immediate;

database closed.
database dismounted.
oracle instance shut down.

sql> startup mount;

oracle instance started.
total system global area 135337420 bytes
fixed size 452044 bytes
variable size 109051904 bytes
database buffers 25165824 bytes
redo buffers 667648 bytes
database mounted.

sql> alter system enable restricted session;

system altered.

sql> alter system set job_queue_processes=0;

system altered.

sql> alter system set aq_tm_processes=0;

system altered.

sql> alter database open;

database altered.

sql> alter database character set internal_use JA16SJIS;
sql> shutdown immediate;
sql> startup;

出现这种问题只要去修改其中一个的编码格式与另一个一致就可以了,相对来说创建系统环境变量的方法更简单一些