2019独角兽企业重金招聘Python工程师标准>>>

参考:

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());}}
//orwhile (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

PostgreSQL JDBC SQLWarning相关推荐

  1. PostgreSQL JDBC 驱动程序版本和JDK关系及下载地址

    JDBC 驱动程序的二进制 JAR 文件下载可在此处获得,当前版本与Maven Repository一起提供.因为 Java 是平台中立的,所以它是一个简单的过程,只需下载适当的 JAR 文件并将其放 ...

  2. spring 启动报错:org.postgresql.jdbc.PgConnection.createClob() 方法尚未被实作。

    该错误并不影响项目里其他接口的调用,仅仅是启动时控制台会打印出来,看起来不舒服. 2022-01-25 15:53:40.718 WARN 8060 --- [ task-1] com.zaxxer. ...

  3. java jdbc sql 参数_java – Postgresql JDBC表值参数

    假设你想从客户端传递值.如果数据库中已存在值,则还有其他更简单的方法- composite_type数组的语法 I know about the option of passing arrays as ...

  4. Postgresql Jdbc 正则表达式问号?的使用

    背景说明:最近在查看项目代码时遇到postgresql正则查询 mybatis配置使用了"??",有些不明白,使用"?"取代,总是遇到错误"Cause ...

  5. JDBC Driver常用连接方法列表

    Microsoft SQL Server series (6.5, 7.x and 2000) and Sybase 10 JDBC Name: jTDS URL: [url]http://jtds. ...

  6. postgresql 子查询_PostgreSQL子事务及性能分析

    作者介绍Laurenz Albe:Cybertec的高级顾问和支持工程师.自2006年以来,一直与PostgreSQL合作并为其做出贡献. 译者简介陈雁飞:开源PostgreSQL爱好者,一直从事Po ...

  7. springboot整合postgresql_SpringBoot+JPA+PostgreSQL整合问题

    理论上本文适用于在使用 JPA+PostgreSQL 时 遇到 org.postgresql.jdbc.PgConnection.createClob() 问题的情况 环境以及主要依赖版本号 Spri ...

  8. JDBC常用连接写法(包括MySQL、Oracle、Sybase、SQLServer、DB2)

    本文引用自CKJ-CLARK<JDBC常用连接写法(包括MySQL.Oracle.Sybase.SQLServer.DB2)> http://apps.hi.baidu.com/share ...

  9. 各种数据库连接jdbc

    链接数据库是很容易突然脑子短路忘掉,转来备用: Microsoft SQL Server series (6.5, 7.x and 2000) and Sybase 10 JDBC Name: jTD ...

最新文章

  1. 死磕算法!35 篇算法设计实例+6 本必读书打包送你
  2. 鼠标滚动倾斜分割切换
  3. BZOJ1941:[SDOI2010]Hide and Seek(K-D Tree)
  4. 计算机上没有启动程序怎么办,Win7开机不加载启动项怎么办
  5. d3 canvas_D3和Canvas分3个步骤
  6. C++编程积累——C++实现十进制与十六进制之间的互相转换
  7. Dubbo SPI的基础Cooma微容器
  8. Tether已在以太坊扩容方案Hermez Network上发行USDT
  9. Throwable、Error、Exception、RuntimeException 区别
  10. Electron——常用的工具列表
  11. 修改tomcat日志数据路径
  12. MATLAB插值函数_akala啦_新浪博客
  13. 用非门74HC04与无源晶振产生时钟信号的两种电路
  14. (20200410已解决)ValueError: Cannot convert non-finite values (NA or inf) to integer
  15. ESP32自动更新气象站
  16. python操作Excel、Word、PDF集合大全
  17. 输出任意边长的菱形————C语言实践应用(1)(完整源码)
  18. 安卓ios文件上传.net 服务器,Windows 和 iOS 13无缝传输文件最快的方案
  19. python安装与应用
  20. Angular学习笔记-使用工厂和值声明提供器

热门文章

  1. 全球及中国生物质能利用产业现状调研及十四五建设布局规划报告2021-2027年
  2. 中国餐饮连锁行业前景预测及未来战略规划建议报告2022年版
  3. 隐藏系统运行对话框立即启用
  4. php如何实现省市,PHP简单实现正则匹配省市区的方法
  5. 长白山特色产品谋定农民丰收节交易会 吉林蛟河农商互联
  6. 王侠对话农民丰收节交易会 万祥军:解读供销社服务平台
  7. VS Code 的常用快捷键和插件
  8. app 性能优化的那些事(二)
  9. 移动測试技术保护源码!解码全球首款移动端白盒測试工具ThreadingTest (文章转自己主动点科技)...
  10. Linux常用命令英文全称与中文解释Linux系统