如何优雅处理SQL存储过程异常_使用TRY-CATCH块机制

TRY-CATCH只捕获运行时错误(如除零、主键冲突),不捕获编译期错误(如语法错、对象不存在);DDL语句出错可能中断批处理,CATCH来不及触发;RAISERROR需≥11级才被捕获;CATCH中须立即用ERROR_*函数保存错误信息;事务回滚前须检查XACT_STATE()。SQL Server 里 TRY-CATCH 不生效?检查是否在批处理顶层TRY-CATCH 在 SQL Server 中只捕获运行时错误(如除零、主键冲突),但不捕获编译期错误(如语法错、对象不存在)------这类错误根本不会进入 TRY 块。最常见误用是把 TRY-CATCH 写在存储过程内部却忘了它只对当前批处理有效。确保 TRY 块从批处理开头开始,不要嵌套在 IF 或循环里再起 BEGIN TRYDDL 语句(如 CREATE TABLE)若出错,可能直接中断批处理,CATCH 来不及触发;建议先用 OBJECT_ID() 检查对象是否存在RAISERROR 的严重级别必须 ≥ 11 才能被 CATCH 捕获;级别 10 及以下是"信息性消息",会直接输出并继续执行如何在 CATCH 块里拿到完整错误信息仅靠 ERROR_MESSAGE() 往往不够,比如主键冲突时提示模糊,你得结合上下文定位问题。SQL Server 提供一组 ERROR_* 函数,必须在 CATCH 块第一行就保存,否则后续语句可能覆盖它们的值。立刻存入变量:DECLARE @msg NVARCHAR(4000) = ERROR_MESSAGE(); DECLARE @sev INT = ERROR_SEVERITY();ERROR_LINE() 返回出错语句所在行号,但注意:它指代的是 TRY 块内语句的行号,不是整个存储过程文件的行号日志记录时建议拼接:CONCAT('Proc:', OBJECT_NAME(@@PROCID), '; Line:', ERROR_LINE(), '; Msg:', ERROR_MESSAGE())事务在 TRY-CATCH 中没回滚?检查 XACT_STATE()很多人以为进了 CATCH 就自动可以 ROLLBACK,结果报错 The ROLLBACK TRANSACTION request has no corresponding BEGIN TRANSACTION。根本原因是:某些错误(如约束冲突)会让事务进入"不可提交"状态,但事务本身未必已显式开启。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。

相关推荐
学测绘的小杨3 小时前
CompassFusion:一个从 GNSS 到 GNSS/INS 组合导航的独立工程包
python
ClouGence9 小时前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
zzzzzz31010 小时前
当产品经理说这个很简单:我用Python自动化处理奇葩需求的实战指南
python·pycharm·产品经理
雪隐10 小时前
个人电脑玩AI-06让5060 Ti给你打工——不光能画画,Qwen3-TTS还能学人说话,连我老板都信了!
人工智能·后端·python
飞将12 小时前
从零实现数据库(2)——HashIndex + IndexManager
数据库
兵慌码乱1 天前
面向桌面端的资产管理系统分层架构设计与核心模块实现
python·系统架构·sqlite·pyqt5·数据库设计·桌面应用开发·mvc架构
hboot1 天前
AI工程师第三课 - 机器学习基础
python·scikit-learn·kaggle
顾林海1 天前
Agent入门阶段-编程基础-Python:流程控制
python·agent·ai编程
呱呱复呱呱1 天前
Django CBV 源码解读:一个请求是怎么找到你的 get() 方法的
python·django
Nturmoils1 天前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库