Oracle字符集的问题!高分求解! 那么为什么在java程序中用OCI连接上数据库,查询结果就会是乱码呢! 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 修改表props$中NLS_CHARACTERSET为ZHS16GBK 是非常危险的.浏览器中显示为乱马,不一定是oracle 客户端或服务端的问题.先看看oracle 客户端的sqlplus查询出来是否为乱码 问题应该是在weblogic上了,我做了一个应用程序,脱离weblogic环境运行,查询结果中文可以显示.但如何解决呢?郁闷中...... 估计是客户端问题。对于Oracle Enterprise Manager中的所有工具,有一个配置文件名为dbappscfg.properties,修改该文件即可解决上述问题。这个文件的位置在$ORACLE_HOME\sysman\config目录下,用任何的文本编辑器打开该文件,在这个文件里面,找到这样一项,# 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> select name,value$ from props$;NAME VALUE$------------------------------ ----------------------------------------DICT.BASE 2DBTIMEZONE 0:00NLS_LANGUAGE AMERICANNLS_TERRITORY AMERICANLS_CURRENCY $NLS_ISO_CURRENCY AMERICANLS_NUMERIC_CHARACTERS .,NLS_CHARACTERSET ZHS16CGB231280NLS_CALENDAR GREGORIANNLS_DATE_FORMAT DD-MON-RRNLS_DATE_LANGUAGE AMERICANNLS_SORT BINARYNLS_TIME_FORMAT HH.MI.SSXFF AMNLS_TIMESTAMP_FORMAT DD-MON-RR HH.MI.SSXFF AMNLS_TIME_TZ_FORMAT HH.MI.SSXFF AM TZH:TZMNLS_TIMESTAMP_TZ_FORMAT DD-MON-RR HH.MI.SSXFF AM TZH:TZMNLS_DUAL_CURRENCY $NLS_COMP BINARYNLS_NCHAR_CHARACTERSET US7ASCIIGLOBAL_DB_NAME TRUSTDB.US.ORACLE.COMNAME VALUE$------------------------------ ----------------------------------------EXPORT_VIEWS_VERSION 8NLS_RDBMS_VERSION 8.1.7.0.1SQL> select * from V$NLS_PARAMETERS;PARAMETER VALUE---------------------------------------------------------------- ----------------------------------------------------------------NLS_LANGUAGE SIMPLIFIED CHINESENLS_TERRITORY CHINANLS_CURRENCY RMBNLS_ISO_CURRENCY CHINANLS_NUMERIC_CHARACTERS .,NLS_CALENDAR GREGORIANNLS_DATE_FORMAT DD-MON-RRNLS_DATE_LANGUAGE SIMPLIFIED CHINESENLS_CHARACTERSET ZHS16CGB231280NLS_SORT BINARYNLS_TIME_FORMAT HH.MI.SSXFF AMNLS_TIMESTAMP_FORMAT DD-MON-RR HH.MI.SSXFF AMNLS_TIME_TZ_FORMAT HH.MI.SSXFF AM TZH:TZMNLS_TIMESTAMP_TZ_FORMAT DD-MON-RR HH.MI.SSXFF AM TZH:TZMNLS_DUAL_CURRENCY RMBNLS_NCHAR_CHARACTERSET US7ASCIINLS_COMP BINARY我按照你说的修改后,重启之后,还是乱码 如果是win2000在注册表中的参数:\hkey_local_machine\software\oracle\home0\下修改NLS_LANG=SIMPLIFIED CHINESE_CHINA.ZHS16GBK注意:服务器和客户端保持一致 linux下!你在oracle的环境变量 .bash_profile 中修改export NLS_LANG="SIMPLIFIED CHINESE_CHINA.ZHS16GBK"; 在脚本里面添上<meta http-equiv="Content-Type" content="text/html; charset=gb2312">试试看 谢谢各位热情支持,不过问题最终是出在weblogic上,已经解决,谢谢大家! 请教关于分区和user_extents表的问题 java调用存储过程时出错,在线等 Oralce 密集数据插入问题! 怎样实现两张表之间的数据更新 使用Pl/sql developer 查看执行计划时,怎么看Statistics啊!! 如何把sql7.0中的视图直接导入到oracle8.0.5中? 非常混沌的问题?!在线 各位高手,请问哪儿有ORACLE9i的中文版下,谢谢大家!! 再问jlandzpa(欧高黎嘉陈) 老兄? 帮我看下这个触发器是否正确 用toad怎么获得sql语句执行的详细情况 如何取消角色密码。
但如何解决呢?郁闷中......
对于Oracle Enterprise Manager中的所有工具,有一个配置文件名为dbappscfg.properties,修改该文件即可解决上述问题。这个文件的位置在$ORACLE_HOME\sysman\config目录下,用任何的文本编辑器打开该文件,在这个文件里面,找到这样一项,
# 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> select name,value$ from props$;NAME VALUE$
------------------------------ ----------------------------------------
DICT.BASE 2
DBTIMEZONE 0:00
NLS_LANGUAGE AMERICAN
NLS_TERRITORY AMERICA
NLS_CURRENCY $
NLS_ISO_CURRENCY AMERICA
NLS_NUMERIC_CHARACTERS .,
NLS_CHARACTERSET ZHS16CGB231280
NLS_CALENDAR GREGORIAN
NLS_DATE_FORMAT DD-MON-RR
NLS_DATE_LANGUAGE AMERICAN
NLS_SORT BINARY
NLS_TIME_FORMAT HH.MI.SSXFF AM
NLS_TIMESTAMP_FORMAT DD-MON-RR HH.MI.SSXFF AM
NLS_TIME_TZ_FORMAT HH.MI.SSXFF AM TZH:TZM
NLS_TIMESTAMP_TZ_FORMAT DD-MON-RR HH.MI.SSXFF AM TZH:TZM
NLS_DUAL_CURRENCY $
NLS_COMP BINARY
NLS_NCHAR_CHARACTERSET US7ASCII
GLOBAL_DB_NAME TRUSTDB.US.ORACLE.COMNAME VALUE$
------------------------------ ----------------------------------------
EXPORT_VIEWS_VERSION 8
NLS_RDBMS_VERSION 8.1.7.0.1SQL> select * from V$NLS_PARAMETERS;PARAMETER VALUE
---------------------------------------------------------------- ----------------------------------------------------------------
NLS_LANGUAGE SIMPLIFIED CHINESE
NLS_TERRITORY CHINA
NLS_CURRENCY RMB
NLS_ISO_CURRENCY CHINA
NLS_NUMERIC_CHARACTERS .,
NLS_CALENDAR GREGORIAN
NLS_DATE_FORMAT DD-MON-RR
NLS_DATE_LANGUAGE SIMPLIFIED CHINESE
NLS_CHARACTERSET ZHS16CGB231280
NLS_SORT BINARY
NLS_TIME_FORMAT HH.MI.SSXFF AM
NLS_TIMESTAMP_FORMAT DD-MON-RR HH.MI.SSXFF AM
NLS_TIME_TZ_FORMAT HH.MI.SSXFF AM TZH:TZM
NLS_TIMESTAMP_TZ_FORMAT DD-MON-RR HH.MI.SSXFF AM TZH:TZM
NLS_DUAL_CURRENCY RMB
NLS_NCHAR_CHARACTERSET US7ASCII
NLS_COMP BINARY
我按照你说的修改后,重启之后,还是乱码
在注册表中的参数:\hkey_local_machine\software\oracle\home0\下修改
NLS_LANG=SIMPLIFIED CHINESE_CHINA.ZHS16GBK注意:服务器和客户端保持一致
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
试试看