应统一存储过程参数命名为@p_前缀+小写下划线风格,如@p_user_id;输出参数加_out后缀;需配合依赖检查、调用方更新及头部注释,并通过CI阶段SQL Lint强制执行。存储过程参数命名不统一,导致调用方难以理解SQL 存储过程中参数名五花八门:@UserID、@user_id、@p_id、@in_userId......调用时得翻源码猜含义,协作和维护成本直线上升。核心是建立可执行的命名契约,不是写文档。推荐统一用 @p_ 前缀 + 小写下划线风格,比如 @p_user_id、@p_is_active、@p_created_after。前缀 @p_ 明确标识这是「parameter」,和变量 @temp_id、游标 @cur 严格区分开全小写 + 下划线(snake_case)兼容 SQL Server / PostgreSQL / MySQL(大小写敏感环境不出错)避免缩写歧义:@p_usr 不如 @p_user_id 直观;@p_st 是 status 还是 start_time?输出参数加 _out 后缀:@p_user_name_out,比单纯 @user_name 更易识别方向SQL Server 中 ALTER PROCEDURE 时不校验参数名变更影响改了 @uid 为 @p_user_id,但调用方代码还传 @uid,运行时报错 Procedure or function 'xxx' expects parameter '@uid', which was not supplied. ------ 这类错误不会在 ALTER 时暴露,只在运行时炸。必须配合三步动作:ALTER 前先查依赖:SELECT * FROM sys.dm_exec_describe_first_result_set(N'EXEC your_proc @uid=1', NULL, 0) 看当前期望参数更新所有调用方:应用层代码、其他存储过程里的 EXEC your_proc @uid = ...、SSIS 包、报表数据集在存储过程头部加注释块,明确标注参数契约:-- @p_user_id: INT, required, ID of target userMySQL 存储过程中 IN/OUT/INOUT 参数类型与命名需同步约束MySQL 允许 IN user_id INT 这种省略 @ 的写法,但混用风格会让团队困惑。更麻烦的是:类型不一致引发隐式转换,比如 IN user_id VARCHAR(20) 被传入数字 123,可能匹配到 '123 '(带空格)。 Mokker AI AI产品图添加背景
相关推荐
暴躁小师兄数据学院4 分钟前
【AI大数据工程师特训笔记】第02讲:PostgreSQL数据库生态全景沐风___5 分钟前
App 上架之后:如何看数据、获取用户与持续迭代产品暴躁小师兄数据学院7 分钟前
【AI大模型应用开发工程师特训笔记】第04讲(第9章):文件目录操作夜微凉416 分钟前
三、MySQL疯狂打码的少年23 分钟前
CISC vs RISC 对比小新同学^O^27 分钟前
Redis的简单总结暴躁小师兄数据学院28 分钟前
【AI大数据工程师特训笔记】第11讲:正则表达式与正则函数IT龟苓膏36 分钟前
MySQL InnoDB 内存结构与性能调优:Buffer Pool、脏页、刷盘、临时表和 filesort 一篇讲清城数派37 分钟前
2026年500米分辨率DEM地形数据(全球/全国/分省/分市)AAA大运重卡何师傅(专跑国道)42 分钟前
力扣hot100