首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么SQLErrorCode为零?

为什么SQLErrorCode为零?
EN

Stack Overflow用户
提问于 2022-10-04 10:37:39
回答 1查看 35关注 0票数 1

在我的Java程序中,我使用JDBC访问我的PostgreSQL数据库,运行良好。试图捕获SQLExceptions并不真正有效。

我的代码:

代码语言:javascript
复制
...
catch (SQLException se) {
      System.out.println("\nSQLException: " + se.getMessage());
      SqlErrorCode = se.getErrorCode();
      System.out.println("\nSqlErrorCode: " + SqlErrorCode);
}
...

我的查询(由程序生成):

代码语言:javascript
复制
SELECT osm_id, osm_type from   (SELECT osm_dach_admin_boundaries_old.osm_id,
       osm_dach_admin_boundaries_old.osm_type
  FROM osm_dach_admin_boundaries_old 
  FULL OUTER JOIN osm_dach_admin_boundaries
        ON (osm_dach_admin_boundaries_old.osm_id = osm_dach_admin_boundaries.osm_id 
       and osm_dach_admin_boundaries_old.osm_type = osm_dach_admin_boundaries.osm_type)
     WHERE (osm_dach_admin_boundaries_old.osm_id IS NULL 
     OR osm_dach_admin_boundaries.osm_id IS NULL)) foo
 WHERE osm_id is not null order by osm_id, osm_typeXXX;

注意列osm_typeXXX,我添加了该列以强制异常。

运行此查询将导致

代码语言:javascript
复制
SQLException: ERROR: column "osm_typexxx" does not exist
  Hinweis: Perhaps you meant to reference the column "foo.osm_type".
  Position: 533

SqlErrorCode: 0
Closing source SQL-Connection
Closing destination SQL-Connection

为什么SqlErrorCode为零,我如何解决这个问题?

EN

回答 1

Stack Overflow用户

发布于 2022-10-04 10:47:56

java.sql.SQLException.getErrorCode()被记录为:

检索此SQLException对象的特定于供应商的异常代码。

现在,PostgreSQL没有特定于供应商的错误代码,而是使用符合标准的SQLSTATE。

所以你应该使用java.sql.SQLException.getSQLState()

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73946617

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档