news 2026/5/15 23:59:19

如何提升SQL存储过程逻辑复用_封装通用存储过程函数

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
如何提升SQL存储过程逻辑复用_封装通用存储过程函数

SQL Server无函数式存储过程,需用标量函数(单值计算)或表值函数(结果集)替代;标量函数禁用DML和非确定性函数,ITVF性能优于MSTVF;MySQL函数须声明DETERMINISTIC等属性;跨库复用宜用视图+参数化查询。SQL Server 里没有函数式存储过程,得用标量函数或表值函数替代SQL Server 的 CREATE PROCEDURE 本身不支持返回值(除 RETURN 整数状态码外),没法像函数那样嵌入查询中复用逻辑。真想封装通用逻辑,优先选 CREATE FUNCTION ——但必须分清场景:SCALAR 函数适合单值计算(比如格式化日期、脱敏手机号),TABLE 函数适合返回结果集(比如按租户过滤的通用权限视图)。常见错误是强行把带 INSERT/UPDATE/EXEC 的业务逻辑塞进函数——SQL Server 不允许,会直接报错 Invalid use of a side-effecting operator。这类操作只能留在存储过程中,复用靠参数化 + 拆解原子步骤。标量函数不能含 DML、临时表、GETDATE() 等非确定性函数(除非显式声明 WITH SCHEMABINDING 并避开限制)内联表值函数(ITVF)性能好、可推导执行计划;多语句表值函数(MSTVF)会物化中间结果,大数据量下明显变慢函数里调用 EXEC 或动态 SQL 是禁止的,这点比存储过程严格得多MySQL 8.0+ 可用存储函数(FUNCTION),但注意权限和只读限制MySQL 允许创建 CREATE FUNCTION,能返回标量值,也支持在 SELECT 中直接调用。但它对定义者权限要求高:必须有 CREATE ROUTINE 权限,且默认开启 log_bin_trust_function_creators=OFF 时,函数还必须声明为 DETERMINISTIC、NO SQL 或 READS SQL DATA,否则建不成功。典型踩坑是写了个读配置表的函数,没加 READS SQL DATA,执行时报错 This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration。更隐蔽的问题是:函数体内不能修改数据(哪怕只是 INSERT INTO tmp SELECT ...),否则会触发 Not allowed to return a result set from a function。函数名不能和内置函数冲突,比如叫 format_date 没问题,叫 date 就会报错参数类型必须明确指定长度,VARCHAR(50) 不能简写成 VARCHAR返回值类型要和实际 RETURN 的表达式类型严格一致,隐式转换可能失败跨数据库通用复用?别硬套“函数”概念,用视图 + 参数化查询组合PostgreSQL、Oracle、SQL Server 都支持视图,但视图不接受参数。想实现类似效果,得靠客户端传参拼接,或服务端用临时表/表变量兜底。例如在 SQL Server 中,可先用 INSERT INTO #filter_config SELECT @tenant_id, @status,再让通用存储过程从 #filter_config 读取条件——这比硬造一个“万能函数”更可控。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/15 23:57:59

村田创新方案解析:从触觉反馈到柔性电路,看感知与连接技术演进

1. 从展会看村田:一场关于“感知”与“连接”的硬核创新秀每年三月的上海,对于电子行业的从业者来说,都绕不开一场盛会——慕尼黑上海电子展。这不仅是供应商展示肌肉的舞台,更是我们这些一线工程师、产品经理和技术决策者&#x…

作者头像 李华
网站建设 2026/5/15 23:55:54

从蓝屏到丝滑:机械革命轻薄本部署WSL2与Docker的完整避坑指南

1. 为什么选择机械革命轻薄本部署开发环境? 最近两年,机械革命的轻薄本在开发者圈子里悄悄火了起来。我自己用的就是一台机械革命Code 01,当初选择它主要是看中了AMD处理器的性价比和轻薄的机身。但真正开始用它搭建开发环境时,才…

作者头像 李华
网站建设 2026/5/15 23:53:24

3个PDF页面操作技巧:用PDF Arranger轻松管理文档

3个PDF页面操作技巧:用PDF Arranger轻松管理文档 【免费下载链接】pdfarranger Small python-gtk application, which helps the user to merge or split PDF documents and rotate, crop and rearrange their pages using an interactive and intuitive graphical …

作者头像 李华
网站建设 2026/5/15 23:52:44

2026年技术招聘市场的结构性变化:初级岗萎缩,专家岗紧缺

一、市场全景:分化已成定局,回暖并非普惠从宏观数据看,技术岗位招聘市场在2026年确实呈现回暖迹象。CompTIA报告显示,美国科技行业预计净增超18.5万个新岗位,增速达1.9%;国内春招招聘企业数同比增长7.4%&am…

作者头像 李华
网站建设 2026/5/15 23:52:42

Keil MDK效率翻倍秘籍:自定义AStyle快捷键,实现Ctrl+Shift+F一键美化代码

Keil MDK效率翻倍秘籍:自定义AStyle快捷键,实现CtrlShiftF一键美化代码 在嵌入式开发领域,代码整洁度直接影响着团队协作效率和后期维护成本。对于使用Keil MDK的资深工程师而言,复制粘贴第三方代码后的格式混乱问题几乎成为日常开…

作者头像 李华