PostgreSQL JDBC SQLWarning

参考:

https://blog.csdn.net/tbc123tbc/article/details/78845844

https://www.cnblogs.com/xiao2/p/7215785.html

 

SQLException

当使用 JDBC 与数据源(我们实际使用的数据库)进行交互时,遇见错误将会主动抛出名为 SQLException 的异常。

SQLException 的主要构成如下,用于帮助我们更好的定位错误:
message:
	错误详情
	使用 getMessage 方法获取。
SQLState
	代码有五位的字母和数字组成 。多数的代码由 ISO/ANSI 和 Open Group(X/Open) 标准化,但是仍然存在部分的代码由数据库提供商自行实现。
	使用 getSQLState 方法获取。
ErrorCode
	与 SQLState 不同,错误代码是由数据库提供商自行定义的整数值,存在是由基础数据源返回的实际错误代码的可能。
	使用 getErrorCode 方法获取。
cause
	表示引发异常的原因,通过不断调用 getCause 方法可以获取异常发生的底层原因。
异常链(NextException)
	如果出现多个错误,则通过此链引用异常。
	使用 getNextException 方法获取。

异常链(NextException)的遍历

            SQLWarning warn = stmt.getWarnings();
            if(warn != null)
            {
                for (Throwable e : warn)
                {
                    logger.debug(e.getMessage());
                }
            }
//or
            while (ex != null)
            {
                logger.error("SQLState:" + ex.getSQLState());
                logger.error("Error Code:" + ex.getErrorCode());
                logger.error("Message:" + ex.getMessage());
                Throwable t = ex.getCause();
                while (t != null)
                {
                    System.out.println("Cause:" + t);
                    t = t.getCause();
                }
                ex = ex.getNextException();
            }

 

SQLWarning

是 SQLException 的一个子类,用于表示数据库访问时出现的警告。 作为异常,SQLWarning 不会停止执行应用程序,而是提醒用户没有按计划发生任何事情。比如,警告有可能会通知你尝试撤销的某个权限没有成功,或者通知你在请求断开的时间可能发生错误。

SQLWarning的主要构成与SQLException相同,有message, SQLState,ErrorCode, cause,异常链(NextWarning)。

SQLWarning 有可能被 Connection 、Statement (包括 PreparedStatement 和 CallableStatement)或 ResultSet 报告,这些类都存在 getWarnings 方法,通过调用该方法才能看到调用对象上报告的第一个警告。如果 getWarning 返回一个警告,我们可以调用其 getNextWarning 方法获取下一个警告。每执行一行语句,那么前面那行语句的警告将会清除,这意味着如果我们想要检索报告处理来的警告,那么必须在下一行语句执行之前检索。
 

异常链(NextWarning)的遍历方法

            SQLWarning warn = stmt.getWarnings();
            if(warn != null)
            {
                for (Throwable e : warn)
                {
                    logger.debug(e.getMessage());
                }
            }

DataTruncation 是最常见的警告,其SQLState代码均为01004,表示在读取和写入数据的时候存在问题。DataTruncation 有很多方法可以帮助我们去理解哪个列或参数数据被截断,截断是在读取还是写入操作,应该传输多少字节以及实际传输的字节数。

 

SQLState == PG Error Code

ref: https://www.postgresql.org/docs/10/errcodes-appendix.html

 

转载于:https://my.oschina.net/liuyuanyuangogo/blog/3000106

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值