我的环境时redhat5 + oracle10g
在linux中运行一个jar包,jar的作用是连接到数据库,并从数据库中导入有关数据.
使用java -jar 123.jar,但系统报如下错误,请各位哥哥姐姐帮帮忙,分析一下. 我怀疑是字符集的问题,可就是不知道怎么解决,谢谢大家了.
[oracle@server2 jingfenfile]$ java -jar WriteFile.jar
??????
2009?05?14? 11?20?13?
path = /jingfenfile
java.sql.SQLException: ORA-00604: error occurred at recursive SQL level 1
ORA-12705: invalid or unknown NLS parameter value specified   at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:111)
   at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:330)
   at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:282)
   at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:277)
   at oracle.jdbc.driver.T4CTTIoauthenticate.receiveOauth(T4CTTIoauthenticate.java:784)
   at oracle.jdbc.driver.T4CConnection.logon(T4CConnection.java:361)
   at oracle.jdbc.driver.PhysicalConnection.<init>(PhysicalConnection.java:413)
   at oracle.jdbc.driver.T4CConnection.<init>(T4CConnection.java:164)
   at oracle.jdbc.driver.T4CDriverExtension.getConnection(T4CDriverExtension.java:34)
   at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:752)
   at java.sql.DriverManager.getConnection(libgcj.so.7rh)
   at java.sql.DriverManager.getConnection(libgcj.so.7rh)
   at dmt.DBConn.ConnectionManager.getConnection(ConnectionManager.java:136)
   at dmt.DBConn.DBConnection.Query(DBConnection.java:46)
   at dmt.service.Service.getflag(Service.java:21)
   at dmt.action.write.writestaticI(write.java:17)
   at dmt.action.WriteFile.write(WriteFile.java:28)
   at dmt.action.WriteFile.main(WriteFile.java:143)
Exception in thread "main" java.lang.NullPointerException
   at dmt.DBConn.DBConnection.Query(DBConnection.java:47)
   at dmt.service.Service.getflag(Service.java:21)
   at dmt.action.write.writestaticI(write.java:17)
   at dmt.action.WriteFile.write(WriteFile.java:28)
   at dmt.action.WriteFile.main(WriteFile.java:143)

解决方案 »

  1.   

    ORA-00604: 递归某个SQL 层时出现错误  原因:在运行一条递归SQL语句(该语句将应用于对内部表或数据字典的操作)时,发生错误。  方案:如果上述描述的错误所在栈可以被修复,则修复并继续运行;否则,请联系Oracle客服。当然,那是Oracle官方的解决办法。我曾经记得有个高手总结了关于ORA-00604/ORA-04031问题的解决:  修改INIT.ora  添加_db_handles_cached = 0   并重新启动数据库.  分析:ORA-00604这个信息表明,在数据库执行内部SQL语句时,发生了错误。比如,要往表中插入一行数据,但没有可扩展的空间。ORACLE于是去查寻,哪儿可以建立下一个扩展空间,它有多大小,但没有成功。一般在发生ORA-00604错误时,还伴随着其它的错误,例如:ORA-1547等。  首先,应当检查警告文件alertSID.log,查找有关ORA-600类的信息。  该错误最常见的原因是数据库文件initSID.ora中的参数OPEN_CURSORS值太小。可以修改initSID.ora文件,OPEN_CURSORS的值一般为255。修改完后,宕下ORACLE,再重新启动。  还可以设置并启动数据库的事件跟踪功能。在initSID.ora中加上一行:event = "00604 trace name errorstack"   宕下并重新启动ORACLE,使这个事件跟踪参数起作用。这样,当再发生ORA-604错误时,有关信息就保存在TRACE文件中。  造成ORA-604错误的其它原因可能有:  - initSID.ora中,参数DC_FREE_EXTENTS或ROW_CACHE_ENQUEUES太低。可以根据操作系统和数据库的情况,适当增加这两个参数的值,宕下并重新启动ORACLE。  - 运行超出空间(伴随ORA-1547错误)。这时,要对表空间添加新文件,即增加表空间的大小。  - 达到了MAX_EXTENTS(伴随ORA-1556错误)。如果这样,就要修改表,允许更多的扩展。请从技术手册中查找MAX_EXTENTS的最大值。如果已经达到了最大值,必须用compress extents选项,把表卸出(export),再导入(import)数据库中。  案例一:Oracle执行递归查询的时候出错  问题描述:我经常遇到ORA-00604 和ORA-01000(开启游标数量达到最大值)错误。然而,当我检查代码的时候,所有的结果集和语句对象都在最后的块中关闭了(我使用的是JDBC)。我执行的查询是一个Oracle递归查询(以这个开始并通过这个连接)。您能告诉我是哪里出现了问题,以及在什么样的情况下会出现上述的错误吗?  解决方案:可能是init.ora 文件中的open_cursors 参数值的设置太低了。这个参数的默认值是非常低的(50)。它应该设置为200或者更高。即使是你关闭了结果集,但是你并没有在JAVA代码中关闭SQL语句,就会导致这个问题。  如果设置为yes的话,那么确保你的活动连接池启用了(为了性能的原因),否则设置为no。  请你的数据库管理员监视数据库,并看看使用V$OPEN_CURSORS 和 V$SYSSTAT数据字典视图的条目。
      

  2.   

    二楼的大哥,你的方法太复杂了,我是菜鸟看不懂啊,有没有具体点的解决方法呢?一楼的大哥,按照你的方法,系统打印如下信息:
    [oracle@server2 jingfenfile]$ echo $NLS_LANG
    American.America.ZHS16GBK
    [oracle@server2 jingfenfile]$ 我查了数据库的字符集
    select * from nls_database_parameters 
    其中
    NLS_LANGUAGE         AMERICAN
    NLS_TERRITORY        AMERICA
    NLS_CHARACTERSET     ZHS16GBK和linux系统的字符集一样啊.大家再帮帮我吧,谢谢大哥大姐了.
      

  3.   

    American.America.ZHS16GBK 好像应该是American_America.ZHS16GBK 是笔误?
      

  4.   

    你的NLS_LANG格式错误。下划线。这样:AMERICAN_AMERICA .ZHS16GBK 
      

  5.   

    现在NLS_LANG的格式已经改过来了,但仍然不能启动jar,报错一样.
    请问大家,要连接数据库,是否linux和oracle中的NLS_LANG参数一致才可以?
      

  6.   

    Applies to: 
    Oracle Content Services - Version: 10.1.2.2 to 10.1.2.3
    This problem can occur on any platform.Symptoms
    Applying Content Services patch 10.1.2.3 (Patch # 5049515) fails with the following error:-- 
    *********************** Starting SetRecordCutOffDateAttribute 
    *********************** 
    SetRecordCutOffDateAttribute script started... 
    Failed, IfsException in execute(): 
    language 
    java.sql.SQLException: ORA-12705: invalid or unknown NLS parameter value 
    specified 

    language 
    java.sql.SQLException: ORA-12705: invalid or unknown NLS parameter value 
    specified 


    at 
    oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:124) 
    at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:315) 
    at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:281) 
    at oracle.jdbc.driver.T4C8Oall.receive(T4C8Oall.java:638) 
    at oracle.jdbc.driver.T4CStatement.doOall8(T4CStatement.java:112) 
    at oracle.jdbc.driver.T4CStatement.execute_for_rows(T4CStatement.java:560) 
    at 
    085) 
    at 
    oracle.ifs.server.LibraryConnection.alterSessionLanguage(LibraryConnection.jav 
    a:741) 
    at 
    oracle.ifs.server.LibraryConnection.setSessionLanguage(LibraryConnection.java: 
    490) 
    at oracle.ifs.server.S_Search.open(S_Search.java:292) 
    at 
    oracle.ifs.server.S_LibrarySession.DMOpenSearch(S_LibrarySession.java:6957) 
    at oracle.ifs.beans.LibrarySession.DMOpenSearch(LibrarySession.java:13081) 
    at oracle.ifs.beans.Search.open(Search.java:541) 
    at oracle.ifs.beans.Search.open(Search.java:500) 
    at oracle.ifs.beans.Search.open(Search.java:452) 
    at 
    oracle.ifs.ecm.upgrade.v10_1_2_2_0.SetRecordCutOffDateAttribute.getRecordsMiss 
    ingCutoffDate(SetRecordCutOffDateAttribute.java:223) 
    at 
    oracle.ifs.ecm.upgrade.v10_1_2_2_0.SetRecordCutOffDateAttribute.execute(SetRec 
    ordCutOffDateAttribute.java:73) 
    at 
    oracle.ifs.admin.actions.LibrarySessionAction.perform(LibrarySessionAction.jav 
    a:228) 
    at oracle.ifs.utils.action.ActionQueue.performActions(ActionQueue.java:303) 
    at oracle.ifs.utils.action.ActionQueue.run(ActionQueue.java:229) 
    at java.lang.Thread.run(Thread.java:534) 

    Failed = oracle.ifs.utils.action.ActionFailedException: 
    language 
    java.sql.SQLException: ORA-12705: invalid or unknown NLS parameter value 
    specified 

    oracle.ifs.utils.action.ActionFailedException: 
    language 
    java.sql.SQLException: ORA-12705: invalid or unknown NLS parameter value 
    specified 

    at 
    oracle.ifs.admin.actions.LibrarySessionAction.perform(LibrarySessionAction.jav 
    a:235) 
    at oracle.ifs.utils.action.ActionQueue.performActions(ActionQueue.java:303) 
    at oracle.ifs.utils.action.ActionQueue.run(ActionQueue.java:229) 
    at java.lang.Thread.run(Thread.java:534) 
    oracle.ifs.utils.action.ActionFailedException: 
    language 
    java.sql.SQLException: ORA-12705: invalid or unknown NLS parameter value 
    specified 

    at 
    oracle.ifs.admin.actions.LibrarySessionAction.perform(LibrarySessionAction.jav 
    a:235) 
    at oracle.ifs.utils.action.ActionQueue.performActions(ActionQueue.java:303) 
    at oracle.ifs.utils.action.ActionQueue.run(ActionQueue.java:229) 
    at java.lang.Thread.run(Thread.java:534) 
    language 
    java.sql.SQLException: ORA-12705: invalid or unknown NLS parameter value 
    specified 


    at 
    oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:124) 
    at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:315) 
    at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:281) 
    at oracle.jdbc.driver.T4C8Oall.receive(T4C8Oall.java:638) 
    at oracle.jdbc.driver.T4CStatement.doOall8(T4CStatement.java:112) 
    at oracle.jdbc.driver.T4CStatement.execute_for_rows(T4CStatement.java:560) 
    at 
    085) 
    at 
    oracle.ifs.server.LibraryConnection.alterSessionLanguage(LibraryConnection.jav 
    a:741) 
    at 
    oracle.ifs.server.LibraryConnection.setSessionLanguage(LibraryConnection.java: 
    490) 
    at oracle.ifs.server.S_Search.open(S_Search.java:292) 
    at 
    oracle.ifs.server.S_LibrarySession.DMOpenSearch(S_LibrarySession.java:6957) 
    at oracle.ifs.beans.LibrarySession.DMOpenSearch(LibrarySession.java:13081) 
    at oracle.ifs.beans.Search.open(Search.java:541) 
    at oracle.ifs.beans.Search.open(Search.java:500) 
    at oracle.ifs.beans.Search.open(Search.java:452) 
    at 
    oracle.ifs.ecm.upgrade.v10_1_2_2_0.SetRecordCutOffDateAttribute.getRecordsMiss 
    ingCutoffDate(SetRecordCutOffDateAttribute.java:223) 
    at 
    oracle.ifs.ecm.upgrade.v10_1_2_2_0.SetRecordCutOffDateAttribute.execute(SetRec 
    ordCutOffDateAttribute.java:73) 
    at 
    oracle.ifs.admin.actions.LibrarySessionAction.perform(LibrarySessionAction.jav 
    a:228) 
    at oracle.ifs.utils.action.ActionQueue.performActions(ActionQueue.java:303) 
    at oracle.ifs.utils.action.ActionQueue.run(ActionQueue.java:229) 
    at java.lang.Thread.run(Thread.java:534) 


    --Changes
    No changes were done since installationCause
    From sqlplus run the following command: SELECT value FROM NLS_SESSION_PARAMETERS WHERE PARAMETER = 'NLS_LANGUAGE'; It returns a value other than "AMERICAN".  Most likely reason for this is the OS locale was not set correctly when Content Services was installed.Solution
    1.Go into Enterprise Manager and follow the links:2.Farm - apps tier - Content - Service Configurations -3.Search for "DefaultLanguage"4.Ensure that is set to AMERICAN5.Apply patch now.