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 输出中间值辅助调试
基本上就这些。掌握基本语法后,结合具体业务场景灵活使用即可。注意参数类型要与表字段匹配,调用时别忘了检查变量作用域。不复杂但容易忽略细节。
