使用空 SQL 状态获取错误代码 4220

Posted

技术标签:

【中文标题】使用空 SQL 状态获取错误代码 4220【英文标题】:Getting error code 4220 with null SQL State 【发布时间】:2013-05-30 10:24:02 【问题描述】:

我收到错误代码 -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

【问题讨论】:

【参考方案1】:

我通过使用最新版本的 jar 并通过设置下面的系统属性解决了这个问题。

System.setProperty("db2.jcc.charsetDecoderEncoder", "3");

另外一种方法是在 DB2 SP 中禁用 char 和 varchar 类型的 unicode 编码,这也对我有用..

【讨论】:

如何“在 DB2 SP 中禁用 char 和 varchar 类型的 unicode 编码”,请您解释一下。【参考方案2】:

在遇到同样的错误后,原来旧版本的 db2jcc jar 不支持 Java 8。恢复到 Java 7 后,错误消失了。这也可以通过从 IBM 下载更新/支持的 jar 版本来解决。

【讨论】:

【参考方案3】:

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

You need to download the appropriate jar from the IBM site

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

问题就解决了:)

【讨论】:

【参考方案4】:

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

【讨论】:

【参考方案5】:

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

【讨论】:

【参考方案6】:

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

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

【讨论】:

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

错误无法获取 APNS 令牌错误域 = com.firebase.iid 代码 = 1001“(空)”

由于 SQL 异常错误,无法将电子邮件属性保存到 sql 中:“不允许空插入”,除非属性不为空??(ORM 代码优先)

AngularJS $http 获取返回空状态 0

Whitelabel 错误页面出现意外错误(类型=内部服务器错误,状态=500)。空标识符

php 64 位 SQL 状态 IM002 错误中的 MS Access DB

获取空指针异常错误空值被传递