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助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
傻啦嘿哟2 小时前
如何在 Python 中使用 colorama 库来给输出添加颜色forEverPlume2 小时前
mysql如何实现高可用集群架构_基于MHA环境搭建与部署草莓熊Lotso3 小时前
Vibe Coding 时代:LangChain 与 LangGraph 全链路解析方安乐7 小时前
python之向量、向量和、向量点积zh1570239 小时前
JavaScript中WorkerThreads解决服务端计算瓶颈代码AI弗森9 小时前
一文理清楚“算力申请 / 成本测算 / 并发评估”蜡台9 小时前
Python包管理工具pip完全指南-----2Mr.朱鹏9 小时前
【Python 进阶 | 第四篇】Psycopg3 + Flask 实现 PostgreSQL CRUD 全流程:从连接池到RESTful接口摇滚侠10 小时前
expdp 查看帮助