news 2026/4/20 6:13:48

MySQL 存储过程与函数:核心辨析与应用指南

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MySQL 存储过程与函数:核心辨析与应用指南

一、 存储过程(Stored Procedure)

存储过程是一组预编译并存储在数据库中的 SQL 语句集合,可视为在数据库端封装的可重复调用业务逻辑单元。它侧重于执行一系列操作,不一定返回结果值。

示例:创建并调用存储过程

sql

DELIMITER //

CREATE PROCEDURE sp_add_user(IN p_user_name VARCHAR(50))

BEGIN

INSERT INTO user(name, create_time) VALUES (p_user_name, NOW());

END //

DELIMITER ;

调用方式

CALL sp_add_user('Tom');

核心特点:支持复杂的业务逻辑流程控制、事务管理,以及通过 `IN`、`OUT`、`INOUT` 参数与调用方交互。

二、 函数(Stored Function)

函数是必须返回一个确定值的数据库程序单元。它常用于计算、数据转换或格式化,并能直接嵌入 SQL 语句中作为表达式使用。

示例:创建并调用函数

sql

DELIMITER //

CREATE FUNCTION fn_get_user_count()

RETURNS INT

DETERMINISTIC

READS SQL DATA

BEGIN

DECLARE v_count INT;

SELECT COUNT() INTO v_count FROM user;

RETURN v_count;

END //

DELIMITER ;

调用方式(可嵌入SQL)

SELECT fn_get_user_count();

SELECT id, name FROM user WHERE LENGTH(name) > fn_get_min_length();

核心特点:必须有返回值,通常不修改数据库状态,主要用于查询和计算场景。

三、 核心区别对比

对比维度存储过程函数
返回值可选(可通过OUT参数返回)必须且仅能返回一个值
调用方式`CALL procedure_name(...);`在SQL语句中直接调用 `SELECT function_name(...);`
主要用途封装业务逻辑、执行批量更新、数据处理等操作执行计算、数据格式化、条件判断等
SQL语句嵌入不可直接嵌入SELECT等语句可直接作为表达式嵌入SQL
参数模式支持 IN, OUT, INOUT仅支持 IN
事务控制支持(可包含 BEGIN/COMMIT/ROLLBACK)通常不支持(除非在存储过程中调用)
适用场景月度报表生成、数据迁移、复杂业务规则处理金额四舍五入、手机号脱敏、状态值映射转换

四、 选型建议与应用场景

选择存储过程当:

业务逻辑复杂,涉及多步SQL操作和事务控制。

需要执行批量数据操作(增删改),尤其追求在数据库端减少网络交互次数。

逻辑主要在数据库内部完成,作为API提供给应用程序调用。

选择函数当:

目的是进行一个计算或转换,并得到一个可用于SQL表达式的标量值。

需要在查询中频繁复用的通用逻辑,例如数据清洗、格式标准化、动态条件计算。

逻辑相对独立,不改变数据状态,符合确定性函数特性。

五、 总结

简而言之,可将存储过程视为数据库中的可执行程序,用于处理复杂的操作流程;而函数则是可重用的计算表达式,旨在封装计算逻辑并返回结果值。

决策口诀:

封装流程与操作 → 采用存储过程

封装计算与取值 → 采用函数

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

代码随想录算法训练营第三十五天 | 121. 买卖股票的最佳时机、122.买卖股票的最佳时机II、123.买卖股票的最佳时机III

代码随想录算法训练营第三十五天任务121. 买卖股票的最佳时机122.买卖股票的最佳时机II123.买卖股票的最佳时机III121. 买卖股票的最佳时机 题目链接:121. 买卖股票的最佳时机 贪心思路:前期尽可能地低价买入,后期尽可能地高价卖出。 class…

作者头像 李华
网站建设 2026/4/18 11:47:19

ATTO系列荧光染料

ATTO是最为常见的荧光染料之一,其可作为一系列生物分子如蛋白质和核酸的荧光标记和分子探针,其波谱涵盖了从紫外光到近红外光范围,是最全波段的荧光标记。与其他染料相比,其在红色光谱区中拥有优良的光稳定性和亮度。 高荧光量子…

作者头像 李华
网站建设 2026/4/19 10:55:58

BODIPY系列荧光染料

BODIPY系列染料,也常叫吡咯硼,BDP系列,是以硼二吡咯(boron-dipyrromethene)为荧光结构母核的染料。BODIPY系列染料的主要特点是结构非对称性,这种不对称的二咯结构可以让BODIPY衍生出非常多样的结构和非常广泛的光谱范围&#xff…

作者头像 李华
网站建设 2026/4/18 13:12:29

22、Linux系统进程管理、内存使用监测与日志文件查看指南

Linux系统进程管理、内存使用监测与日志文件查看指南 1. 识别运行进程 在Linux系统中,了解系统负载和运行进程对于系统管理和故障排查至关重要。负载平均值能反映系统的整体负载情况。例如,在一个四核CPU的系统中,负载平均值为4.0意味着进程对CPU时间的需求恰好等于计算机…

作者头像 李华
网站建设 2026/4/18 18:09:55

24、深入了解 Linux 文本编辑与脚本编写

深入了解 Linux 文本编辑与脚本编写 1. vi/vim 编辑器简介 vi 是为 Unix 编写的第一个全屏文本编辑器,它体积小巧,能适配老式的基于软盘的紧急引导系统。后来,GNU 项目开发了 vi 编辑器的开源替代品,增加了一些改进,称为 “vi improved”,即 vim。尽管大多数 Linux 发行…

作者头像 李华
网站建设 2026/4/18 18:21:25

29、Linux 用户账户管理全攻略

Linux 用户账户管理全攻略 1. 创建新账户 在大多数情况下,当创建新账户时,很多选项使用默认值即可,此时点击“确定”就能完成基本的账户创建操作。新账户会出现在“用户”标签列表中,后续若有需要,还可以对其进行修改或删除。 1.1 从命令行创建账户 在各种 Linux 发行…

作者头像 李华