补充数据库服务器的详细信息:NAME VALUE$
------------------------------ ---------
NLS_LANGUAGE AMERICAN
NLS_TERRITORY AMERICA
NLS_CHARACTERSET ZHS16GBK
------------------------------ ---------
NLS_LANGUAGE AMERICAN
NLS_TERRITORY AMERICA
NLS_CHARACTERSET ZHS16GBK
# SQLPLUS_NLS_LANG=AMERICAN_AMERICA.WE8ISO8859P1
去掉注释符#,同时将其修改为SQLPLUS_NLS_LANG=AMERICAN_AMERICA.ZHS16GBK。
对于Windows操作系统,还需要修改一项,在文件中找到# SQLPLUS_SYSTEMROOT=c:\\WINNT40,去掉注释符,将其修改为你所在机器的操作系统主目录。如操作系统的主目录在D盘的Winnt下,则将其修改为 SQLPLUS_SYSTEMROOT=d:\\WINNT。
对于后面一项的修改只对Windows操作系统进行,对UNIX操作系统则不需要。如果在Windows操作系统中不修改该项,在Oracle Enterprise Manager中,连接系统时,会提示如下的错误:
ORA-12560 TNS:protocol adapter error
或者
ORA-12545 Connect failed because target host or object does not exist
修改完成后,保存文件,退出编辑。重新连接SQL PLUS Worksheet,字符集乱码问题得到解决,显示正确的简体中文字符集。
谢谢大哥的回复,^_^
可能是我的问题讲的不清楚,我是希望如何修改Oracle的客户端,使之与服务器端一致。
因为我看到一篇关于如何修改客户端字符集的文章,
里面讲道“对于采用服务器端/客户端方式,两端字符集不同 修改客户端字符集:WIN95/WIN98:修改注册表 HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\NLS_LANG”
我的Oracle客户端是win2000,不知道能不能通过这种修改注册表实现修改字符集?如果可以,将设为何值?是跟服务器端一样的值吗?即:ZHS16GBK??
我不是很清楚。
HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\NLS_LANG
or
HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\HOME0\NLS_LANGto
AMERICAN_AMERICA.ZHS16GBK