获取具有空SQL状态的错误代码4220

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了获取具有空SQL状态的错误代码4220相关的知识,希望对你有一定的参考价值。

我收到错误代码-4220与空SQL状态.SP“XXXXX”包含VARGRAPHICS数据类型。下面是完整的异常堆栈跟踪。 SP正在正确执行,在读取输出参数时出现错误,即执行方法调用成功,但getString方法给出错误。

即使我正在尝试访问任何方法来获取输出参数值,也会出现错误。仅供参考,我尝试使用最新版本的db2驱动程序,但仍然存在错误。

    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编码,这也对我有用..

另一答案

在经历了同样的错误之后,结果发现旧版本的db2jcc jar不支持Java 8.在恢复到Java 7之后,错误就消失了。这也可以通过从IBM下载更新/支持的jar版本来解决。

另一答案

经过大量的研究,我发现要下载的确切jar来解决CharConversionException。再具体一点。此问题已在JDBC v9.7修订包5中得到解决。此版本解决了APAC74895(它解决了CharConversionException),以便跳过db中的特殊字符而不是抛出异常。

You need to download the appropriate jar from the IBM site

然后在ur tomcat设置中添加以下环境变量(Java VM参数)-Ddb2.jcc.charsetDecoderEncoder = 3

多数民众赞成解决问题:)

另一答案

将DB列从CHAR更改为VARCHAR后,我们遇到此问题。重新启动Java WAS服务器后问题得以解决 - 显然DB2驱动程序需要重新启动才能解决这个问题。

另一答案

db2jcc.jar驱动程序现已弃用。

确定您的db2版本并将最新的db2jcc jar文件包含在构建路径中。

在我的情况下:Db2版本= 9.7.301.326,我补充说

db2jcc-9.7.4.jar

刷新并重新运行您的应用程序。它对我有用。

有关更多详细信息:http://www-01.ibm.com/support/docview.wss?uid=swg21363866

另一答案

我遇到了问题,因为我的db2jcc jar已经过时,我的服务器指向过时的jar来获取db2连接。

更新db2jcc jar解决了我的问题。

以上是关于获取具有空SQL状态的错误代码4220的主要内容,如果未能解决你的问题,请参考以下文章

休息模板中具有 307 状态代码的空响应实体

AngularJS $http 获取返回空状态 0

使用回收器适配器获取空指针

Android Java:在 onCreateView() 中返回空视图的片段

如何获取数据集中具有空值的列的总数? [复制]

解释'空'C数组(int a = {};)