SQL Server 存储过程开发规范

SQL Server 存储过程开发规范(高级版)

1. 总则

1.1 目标

本规范旨在:

  • 提高存储过程的事务一致性异常可追踪性错误透明度

  • 统一日志记录错误码管理链路追踪(Trace ID)

  • 支持复杂事务场景(嵌套事务、分布式事务)

  • 为持续集成(CI/CD)提供自动化测试与发布支持

2. 存储过程分层与职责

层次控制事务记录异常日志返回状态码Trace ID说明
Main(主流程)生成并传递 Trace ID,汇总状态
SubTx(子事务)独立事务单元,异常即回滚
Func(功能操作)可选可选查询或计算操作

3. 日志表设计(Log表标准化)

设计统一、专业的日志表,以支持问题追踪和运维排查。

3.1 错误日志表结构(示例)

CREATE TABLE dbo.Proc_Error_Log (LogId BIGINT IDENTITY(1,1) PRIMARY KEY,TraceId UNIQUEIDENTIFIER NOT NULL, -- 链路IDProcName NVARCHAR(200) NOT NULL,    -- 存储过程名称ErrorCode INT NOT NULL,             -- 错误码ErrorMessage NVARCHAR(2000) NOT NULL, -- 错误信息StackTrace NVARCHAR(MAX) NULL,       -- 堆栈追踪信息(可选)CreateTime DATETIME2 NOT NULL DEFAULT GETUTCDATE(), -- UTC时间InputParams NVARCHAR(MAX) NULL,     -- 输入参数快照(JSON格式)ExtraInfo NVARCHAR(MAX) NULL        -- 额外上下文信息(如服务器名、环境)
);

3.2 日志写入示例

INSERT INTO dbo.Proc_Error_Log (TraceId, ProcName, ErrorCode, ErrorMessage, InputParams)
VALUES (@TraceId, 'proc_Order_Shipment_Main', @code, ERROR_MESSAGE(), @InputParams);

4. 统一错误代码管理策略

4.1 错误码分层设计

范围说明
0成功
1000-1999业务校验失败(如库存不足、余额不足)
2000-2999数据库操作失败(如更新失败)
3000-3999外部系统调用失败(如支付系统超时)
4000-4999系统异常(如死锁、不可预知异常)

所有错误码及含义应维护一张独立表或配置文件,便于统一维护和前端适配。


5. Trace ID设计与使用

5.1 生成与传递

  • 在主流程入口生成 Trace ID(UUID)。

  • 通过参数传递到每个子事务和日志记录,保证链路统一。

DECLARE @TraceId UNIQUEIDENTIFIER = NEWID();
EXEC proc_Order_Shipment_Main @OrderId, @TraceId, @code OUTPUT, @msg OUTPUT;

5.2 传递规范

  • 所有子过程均必须携带 @TraceId 参数。

  • 日志记录必须关联 TraceId,便于串联问题定位。


6. 复杂事务控制规范

6.1 嵌套子事务(Savepoint)

子事务内部采用 SAVE TRANSACTION,保证局部回滚而非破坏主事务。

BEGIN TRANSACTION;
SAVE TRANSACTION SavePoint_SubTx1;BEGIN TRY-- 子操作
END TRY
BEGIN CATCHROLLBACK TRANSACTION SavePoint_SubTx1;THROW;
END CATCH

6.2 分布式事务(如调用外部数据库)

必须显式使用 BEGIN DISTRIBUTED TRANSACTION,并加快超时时间控制。


7. 存储过程单元测试体系

7.1 Mock数据表设计

为存储过程测试,设计专门的测试版表(如 Order_TestInventory_Test),与正式表结构一致,但独立存在。

  • 测试存储过程前,插入测试数据。

  • 测试结束后,清理数据,保证测试幂等性。

7.2 自动化测试脚本示例

-- Arrange
INSERT INTO Order_Test(OrderId, Status) VALUES (1, 'Pending');-- Act
DECLARE @code INT, @msg NVARCHAR(500);
EXEC proc_Order_Shipment_Main @OrderId = 1, @TraceId = NEWID(), @code OUTPUT, @msg OUTPUT;-- Assert
IF @code != 0PRINT 'Test Failed: ' + @msg;
ELSEPRINT 'Test Passed';

可以将测试脚本集成到CI流程中,保证每次变更均经过验证。


8. 自动化部署策略

8.1 脚本编写规范

  • 存储过程脚本必须支持幂等执行(存在则更新)。

  • 示例:

IF EXISTS (SELECT 1 FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[proc_Order_Shipment_Main]') AND type = N'P')DROP PROCEDURE dbo.proc_Order_Shipment_Main;
GO
CREATE PROCEDURE dbo.proc_Order_Shipment_Main
AS
BEGIN-- 定义
END
GO

8.2 自动发布流程

  1. 开发者提交存储过程脚本至版本库(如 Git)。

  2. CI Pipeline自动检测是否有变更。

  3. 自动化执行发布脚本,部署到测试环境或正式环境。

  4. 发布前自动备份旧版本存储过程。


最后总结

关键能力规范提升点
日志记录统一结构化存储,关联Trace ID
错误处理标准化错误码体系
事务控制支持局部回滚、分布式事务
调试追踪Trace ID贯穿调用链
测试保障mock表+自动化测试
自动部署幂等脚本+CI集成

通过这些规范,能够让SQL Server存储过程开发真正具备企业级生产力,同时大幅降低维护成本和故障排查复杂度。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/78821.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

opendds的配置

配置的使用 文档中说明有4种使用配置的方式: 环境变量 命令行参数(将覆盖环境变量中的配置) 配置文件(不会覆盖环境变量或命令行参数中的配置) 用户调用的 API(将覆盖现有配置) 这里对开发…

(Go Gin)上手Go Gin 基于Go语言开发的Web框架,本文介绍了各种路由的配置信息;包含各场景下请求参数的基本传入接收

1. 路由 gin 框架中采用的路优酷是基于httprouter做的 HttpRouter 是一个高性能的 HTTP 请求路由器,适用于 Go 语言。它的设计目标是提供高效的路由匹配和低内存占用,特别适合需要高性能和简单路由的应用场景。 主要特点 显式匹配:与其他路由…

Marin说PCB之----板材的替换注意事项

由于最近很多武林上的主流门派都需要采用将的本方案,小编所在的宗门古族也是不例外了,宗门大长老韩立现在想把之前一直在用的板材EM370Z替换成生益的Autolad3,让我去拿资料分析一下是否可以替换。下图所示是就是小编我做的一个表格关于两家板…

4月28日信息差全景:国际局势、科技突破与市场震荡一、国际政治与安全:俄乌冲突关键转折

一、国际政治与安全:俄乌冲突关键转折 1. 乌克兰反攻进展与情报差异 前线动态: 俄国防部称在顿涅茨克击退乌军三次进攻,摧毁12辆坦克;乌方则宣布在巴赫穆特南部推进2公里,双方战报存在显著差异。 信息差根源:战场信息管控导致西方媒体与俄媒报道截然不同。 国际援助: 美…

关系数据的可视化

目录 【实验目的】 【实验原理】 【实验环境】 【实验步骤】 一、安装Python所需要的第三方模块 二、实验 【实验总结】 【实验目的】 1.掌握关系数据在大数据中的应用 2.掌握关系数据可视化方法 3. python 程序实现图表 【实验原理】 在传统的观念里面&#xff0…

夏季道路安全的AI革命:节省人力、提升效率

AI夏季道路安全:用智能算法守护每一条街道 背景:夏季道路安全的挑战与机遇 夏季是道路安全事件的高发期。高温天气容易导致驾驶员疲劳、行人行为异常(如跌倒或中暑),同时,车流量增加、夜间活动频繁…

HTML标记语言_@拉钩教育【笔记】

目录 1.文本标签 2.格式化标签 3.图片标签 4.超链接标签 5.表格标签 6表单标签 6.1 6.2 6.3 7.行内框架(超链接内套一个页面) 8.多媒体标签(音/视频) 1.文本标签 2.格式化标签 3.图片标签 4.超链接标签 5.表格标签 6表单标签 6.1 6.2 6.3 7.行内框架(超链接内套一个…

Python 中调用方法内部定义的类详解(类在方法中的各种操作)

更多内容请见: python3案例和总结-专栏介绍和目录 文章目录 一、基本概念1.1 方法内部定义类概述1.2 方法内部定义类的特点1.3 替代方案二、基本使用2.1 直接在方法内部使用2.2 返回类定义供外部使用2.3 返回类的实例2.4 作为闭包使用(访问外部变量)三、高级用法3.1 动态类创…

第36课 常用快捷操作——用“鼠标右键”退出当前命令

概述 在AD 20软件中,很多的命令都是可以一直连续下去的,比方说放置一个元器件符号,如果你当中不取消的话,那就可以一直执行下去,放完一个接着放下一个,放完一个接着放下一个…… 想要退出这种连续进行的命…

FFTW3.3.10库与QT结合的使用

FFTW(Fastest Fourier Transform in the West)是世界上最快的FFT, 实测计算长度为10000的double数组, 单次运行时间在2ms左右。为了详细了解FFTW以及为编程方便,特将用户手册看了一下,并结合手册制作了以下…

服务器异地备份,服务器异地备份有哪些方法?

服务器异地备份是应对区域性灾难(如地震、火灾、洪水)或人为事故(如误删除、勒索病毒攻击)的关键策略,其核心在于将数据副本存储在物理隔离的地理位置,确保主数据中心故障时仍可恢复业务。 以下是主流的异地…

导轨表面硬化处理有哪些?

导轨是机器工作的重要组成部分,它与滑块紧密配合,保证机器的运转精度和定位精度。为了提高导轨的耐磨性能和使用寿命,通常在导轨表面加工硬化层。硬化层一般是在导轨表面形成一层高硬度和高强度的薄层,有效地提高了导轨的耐磨性能…

Android Compose vs 传统View系统:全面对比与选型指南

Android Compose vs 传统View系统:全面对比与选型指南 一、引言 随着Android Jetpack Compose的正式发布,Android开发迎来了全新的声明式UI框架。本文将全面对比Compose与传统View系统的差异,帮助开发者做出合理的技术选型。 二、核心架构…

C#中实现JSON解析器

JSON(JavaScript Object Notation)即 JavaScript 对象表示法,是一种轻量级的数据交换格式。 起源与发展 JSON 源于 JavaScript 编程语言,是 JavaScript 对象字面量语法的一个子集。但如今它已经独立于 JavaScript,成为一种通用的数据格式,广泛应用于各种编程语言和系统…

【Maven】子POM与父POM

文章目录 子POM与父POM一、继承的内容1.子 POM 可以继承父 POM 的内容2.子 POM 中声明相同配置覆盖规则示例 子POM与父POM 一、继承的内容 在 Maven 项目结构中,子 POM(子模块)可以继承父 POM 的很多配置。合理使用继承机制可以大大减少重复…

12前端项目----添加购物车1.0

商品添加购物车 商品数量添加购物车浏览器本地存储localStoragesessionStorage添加成功页面 商品数量 输入为数字&#xff0c;最少为1<div class"cartWrap"><div class"controls"><input autocomplete"off" class"itxt&quo…

EasyRTC嵌入式音视频通信SDK助力视频客服,开启智能服务新时代

一、背景 在数字化服务浪潮下&#xff0c;客户对服务体验的要求日益提升&#xff0c;传统语音及文字客服在复杂业务沟通、可视化指导等场景下渐显不足。视频客服虽成为企业服务升级的关键方向&#xff0c;但普遍面临音视频延迟高、画质模糊、多端适配难、功能扩展性差等问题&a…

干货分享|MaxKB智能问数方案及步骤详解

DeepSeek-R1的发布掀起了AI智能变革的浪潮。在过去几个月里&#xff0c;MaxKB开源企业级AI助手已经帮助大量企业和组织快速落地了DeepSeek&#xff0c;让AI在不同的行业土壤中产生持续、可度量的业务价值。 MaxKB&#xff08;github.com/1Panel-dev/MaxKB&#xff09; 可以为本…

【python】数据类型小结

1.数据类型 int、float、str、bool、元组tuple、列表list、字典dict、集合set 分为两类&#xff1a;可变和不可变数据类型 2.可变数据类型和不可变数据类型 当变量的值变化&#xff0c;内存地址不变则为可变数据类型&#xff0c; eg&#xff1a;int、float、bool、字符串st…

泰山派常用命令

0.连接adb 设备列表&#xff1a;adb devices 进入命令&#xff1a;adb shell 1.连接WiFi 查看当前网络&#xff1a;nmcli con show 我的WiFi名称&#xff1a;6 我的WiFi密码&#xff1a;12345789 连接当前网络&#xff1a;nmcli device wifi connect 6 password 1234578…