Db2 获取SQL状态为空的错误代码4220
我得到的错误代码是-4220,SQL状态为空。SP“XXXXX”包含VARGRAPHICS数据类型。下面是完整的异常堆栈跟踪。SP正在正确执行,读取输出参数时出错,即execute方法调用成功,但getString方法出现错误 即使我试图访问任何方法来获取输出参数值,错误也会出现。仅供参考,我尝试使用最新版本的db2驱动程序,但错误仍然存在Db2 获取SQL状态为空的错误代码4220,db2,spring-jdbc,Db2,Spring Jdbc,我得到的错误代码是-4220,SQL状态为空。SP“XXXXX”包含VARGRAPHICS数据类型。下面是完整的异常堆栈跟踪。SP正在正确执行,读取输出参数时出错,即execute方法调用成功,但getString方法出现错误 即使我试图访问任何方法来获取输出参数值,错误也会出现。仅供参考,我尝试使用最新版本的db2驱动程序,但错误仍然存在 com.ibm.db2.jcc.am.SqlException: [jcc][t4][1065][12306][3.65.77] Caught ja
com.ibm.db2.jcc.am.SqlException: [jcc][t4][1065][12306][3.65.77] Caught java.io.CharConversionException. See attached Throwable for details. ERRORCODE=-4220, SQLSTATE=null
at com.ibm.db2.jcc.am.cd.a(cd.java:682)
at com.ibm.db2.jcc.am.cd.a(cd.java:60)
at com.ibm.db2.jcc.am.cd.a(cd.java:112)
at com.ibm.db2.jcc.am.gc.a(gc.java:2825)
at com.ibm.db2.jcc.am.gc.a(gc.java:582)
at com.ibm.db2.jcc.am.gc.q(gc.java:560)
at com.ibm.db2.jcc.am.gc.N(gc.java:1557)
at com.ibm.db2.jcc.am.gc.a(gc.java:1541)
at com.ibm.db2.jcc.am.CallableStatement.D(CallableStatement.java:941)
at com.ibm.db2.jcc.am.CallableStatement.getString(CallableStatement.java:920)
at com.cst.test.daoLayer.SPTest.callDB2ProcOUTParameter(SPTest.java:118)
at com.cst.test.daoLayer.SPTest.testLogic(SPTest.java:235)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:79)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:618)
at org.junit.internal.runners.TestMethodRunner.executeMethodBody(TestMethodRunner.java:99)
at org.junit.internal.runners.TestMethodRunner.runUnprotected(TestMethodRunner.java:81)
at org.junit.internal.runners.BeforeAndAfterRunner.runProtected(BeforeAndAfterRunner.java:34)
at org.junit.internal.runners.TestMethodRunner.runMethod(TestMethodRunner.java:75)
at org.junit.internal.runners.TestMethodRunner.run(TestMethodRunner.java:45)
at org.junit.internal.runners.TestClassMethodsRunner.invokeTestMethod(TestClassMethodsRunner.java:66)
at org.junit.internal.runners.TestClassMethodsRunner.run(TestClassMethodsRunner.java:35)
at org.junit.internal.runners.TestClassRunner$1.runUnprotected(TestClassRunner.java:42)
at org.junit.internal.runners.BeforeAndAfterRunner.runProtected(BeforeAndAfterRunner.java:34)
at org.junit.internal.runners.TestClassRunner.run(TestClassRunner.java:52)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:45)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:460)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:673)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:386)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:196)
Caused by: java.nio.charset.MalformedInputException: Input length = 5
at com.ibm.db2.jcc.am.r.a(r.java:19)
at com.ibm.db2.jcc.am.gc.a(gc.java:2821)
... 28 more
Caused by: sun.io.MalformedInputException
at sun.io.ByteToCharUTF8.convert(ByteToCharUTF8.java:278)
at com.ibm.db2.jcc.am.r.a(r.java:16)
... 29 more
我通过使用最新版本的jar和在下面设置系统属性来修复这个问题
System.setProperty("db2.jcc.charsetDecoderEncoder", "3");
另一种方法是在DB2 SP中禁用char和varchar类型的unicode编码,这对我也很有用。经过大量研究,我找到了要下载的确切JAR来解决CharConversionException问题。 具体来说。这个问题在JDBCV9.7修复包5中得到了解决。此版本解决了APAC74895(它解决了CharConversionException),因此跳过数据库中的特殊字符,而不是抛出异常 然后在您的tomcat设置中添加以下环境变量(Java VM参数 -Ddb2.jcc.charsetDecoderEncoder=3
问题就这样解决了:)在经历了同样的错误后,发现旧版本的db2jcc-jar不支持java8。在恢复到Java7之后,错误消失了。这也可以通过从IBM下载较新/受支持的jar版本来解决。将DB列从CHAR更改为VARCHAR后,我们遇到了这个问题。在重新启动Java was服务器后,问题得到了解决——显然,DB2驱动程序需要重新启动才能解决这个问题。db2jcc.jar驱动程序现在已被弃用 确定db2版本,并将最新的db2jcc jar文件包含到构建路径中 在我的例子中:DB2Version=9.7.301.326,我添加了
db2jcc-9.7.4.jar
刷新并重新运行你的应用程序。它对我有效
更多细节:我遇到了这个问题,因为我的db2jcc jar已经过时,而我的服务器指向过时的jar以获得db2连接 更新db2jcc jar解决了我的问题。如何“在DB2 SP中禁用char和varchar类型的unicode编码”,请解释一下。