那么为什么在java程序中用OCI连接上数据库,查询结果就会是乱码呢!

解决方案 »

  1.   

    修改表props$中NLS_CHARACTERSET为ZHS16GBK 是非常危险的.浏览器中显示为乱马,不一定是oracle 客户端或服务端的问题.先看看oracle 客户端的sqlplus查询出来是否为乱码
      

  2.   

    问题应该是在weblogic上了,我做了一个应用程序,脱离weblogic环境运行,查询结果中文可以显示.
    但如何解决呢?郁闷中......
      

  3.   

    估计是客户端问题。
    对于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 
    修改完成后,保存文件,退出编辑。
      

  4.   

    不行啊,老大!涛声依旧啊!
    这是两个相关表信息
    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
    我按照你说的修改后,重启之后,还是乱码
      

  5.   

    如果是win2000
    在注册表中的参数:\hkey_local_machine\software\oracle\home0\下修改
    NLS_LANG=SIMPLIFIED CHINESE_CHINA.ZHS16GBK注意:服务器和客户端保持一致
      

  6.   

    linux下!你在oracle的环境变量 .bash_profile 中修改export NLS_LANG="SIMPLIFIED CHINESE_CHINA.ZHS16GBK";
      

  7.   

    在脚本里面添上
    <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
    试试看
      

  8.   

    谢谢各位热情支持,不过问题最终是出在weblogic上,已经解决,谢谢大家!