The First Light Of Day 2023-03-07 17:18 采纳率: 0%
浏览 25

代码执行sql报错事务已终止

错误信息:ERROR: current transaction is aborted, commands ignored until end of transaction block; nested exception is org.postgresql.util.PSQLException: ERROR: current transaction is aborted, commands ignored until end of transaction block
友友们有没有遇到过方法执行时报错事务已终止的问题,有的方法只包含一条简单的sql也会报事务终止。现在猜测是a方法执行sql报错了但是没有回滚或提交,然后前端调用b方法,b方法和a方法获取了同一条数据库连接,导致b方法执行sql报错。但是目前没想到办法验证该问题。前后端交互a和b是分两次调用的

  • 写回答

3条回答 默认 最新

  • 九尾狐的yi巴 2023-03-07 18:26
    关注

    这个问题可能是由于前一个事务没有正确提交或回滚,导致后续事务无法正常执行。建议按照以下步骤进行排查:

    检查代码中是否有正确的事务管理,包括事务的开启、提交或回滚。可以使用 try-catch-finally 语句块来确保事务的正确执行。

    检查数据库连接是否正确释放。如果代码中没有正确释放连接,可能会导致连接池中的连接被耗尽,从而影响后续事务的执行。

    尝试重启应用程序或数据库,以确保事务的清空。可以在执行前清空事务,也可以在执行后清空事务,具体取决于应用程序的需求。

    使用数据库工具检查数据库是否有异常,例如重复数据、约束冲突等。如果数据库中存在异常数据,可能会导致事务出现异常。
    如果以上方法都无法解决问题,建议在代码中加入日志来更好地跟踪问题。同时,可以使用数据库调试工具来检查数据库的执行情况,以便更好地定位问题。

    评论

报告相同问题?

问题事件

  • 创建了问题 3月7日

悬赏问题

  • ¥15 pnpm 下载element-plus
  • ¥15 解决编写PyDracula时遇到的问题
  • ¥15 有没有人能解决下这个问题吗,本人不会编程
  • ¥15 plotBAPC画图出错
  • ¥30 关于#opencv#的问题:使用大疆无人机拍摄水稻田间图像,拼接成tif图片,用什么方法可以识别并框选出水稻作物行
  • ¥15 Python卡尔曼滤波融合
  • ¥20 iOS绕地区网络检测
  • ¥15 python验证码滑块图像识别
  • ¥15 根据背景及设计要求撰写设计报告
  • ¥20 能提供一下思路或者代码吗