mysql存储过程怎么写_mysql存储过程的编写与调用方法

来源:这里教程网 时间:2026-02-28 20:21:29 作者:

MySQL存储过程是一段预编译的SQL代码,可以保存在数据库中并重复调用。使用存储过程能提高执行效率、减少网络开销,并增强代码的可维护性。

一、创建存储过程

使用 CREATE PROCEDURE 语句定义存储过程。基本语法如下:

CREATE PROCEDURE 存储过程名([参数列表])
BEGIN
    -- SQL语句
END

参数格式: [IN | OUT | INOUT] 参数名 参数类型

IN:输入参数,默认类型,调用时传入值 OUT:输出参数,存储过程内赋值,返回给调用者 INOUT:既可输入也可输出

示例1:简单无参存储过程

DELIMITER $$
CREATE PROCEDURE GetUsers()
BEGIN
    SELECT * FROM users;
END $$
DELIMITER ;

说明: 使用 DELIMITER 更改语句结束符,避免与内部分号冲突。

示例2:带输入参数的存储过程

DELIMITER $$
CREATE PROCEDURE GetUserById(IN user_id INT)
BEGIN
    SELECT * FROM users WHERE id = user_id;
END $$
DELIMITER ;

示例3:带输出参数的存储过程

DELIMITER $$
CREATE PROCEDURE CountUsers(OUT total INT)
BEGIN
    SELECT COUNT(*) INTO total FROM users;
END $$
DELIMITER ;

二、调用存储过程

使用 CALL 语句执行存储过程。

调用无参过程:

CALL GetUsers();

调用带输入参数的过程:

CALL GetUserById(5);

调用带输出参数的过程:

CALL CountUsers(@total);
SELECT @total;

说明: @total 是用户变量,用于接收输出值。

三、查看与删除存储过程

查看已创建的存储过程:

SHOW PROCEDURE STATUS WHERE Db = '数据库名';
-- 或模糊查询
SHOW PROCEDURE STATUS LIKE '%user%';

查看存储过程定义:

SHOW CREATE PROCEDURE 存储过程名;

删除存储过程:

DROP PROCEDURE IF EXISTS 存储过程名;

四、实际应用建议

命名规范:使用有意义的名称,如
sp_get_user_info
避免复杂逻辑:尽量保持存储过程简洁,复杂业务建议由应用层处理 注意权限:确保调用者有执行权限 调试技巧:可在过程中加入 SELECT 输出中间值辅助调试

基本上就这些。掌握基本语法后,结合具体业务场景灵活使用即可。注意参数类型要与表字段匹配,调用时别忘了检查变量作用域。不复杂但容易忽略细节。

相关推荐