MySQL 5.0 版本开始支持存储过程。存储过程(Stored Procedure)是数据库中存储的复杂程序,以便外部应用调用的一种数据库对象。存储过程是为了完成特定功能的SQL语句集,经编译创建并保存在数据库中,用户可通过指定存储过程的名字并给定参数(可选)来调用执行。
存储过程可以有效提高 SQL 语句的复用率,并且可以将相关的一组 SQL 放入到存储过程中,从而避免了应用程序的多次查询带来的与 MySQL 服务器的连接延迟和占用的网络资源。下面是一个存储过程的示例,用于传入一个 id 来删除指定 id的学生,并同时删除扩展表中的学生信息。通过这种方式就可以处理相关联的数据,而不需要应用程序分两次 SQL 操作。
DROP PROCEDURE IF EXISTS delete_student_by_id;
delimiter $$
CREATE PROCEDURE delete_student_by_id(IN p_id INT)
BEGIN
DELETE FROM t_students
WHERE id = p_id;
DELETE FROM t_students_info
WHERE student_id = p_id;
END
$$
delimiter ;
DROP PROCEDURE IF EXISTS insert_many_rows;
delemiter //
CREATE PROCEDURE insert_many_rows(IN loops INT)
BEGIN
DECLARE v1 INT;
SET v1=loops;
WHILE v1 > 0 DO
INSERT INTO test_table values(NULL, 0,
'aaaaaaaaaaaabbbbbbbbbb',
'aaaaaaaaaaaabbbbbbbbbb');
SET v1=v1-1;
END WHILE;
END
//
delemiter ;
可以通过与应用程序实现同样的功能进行比较,发现使用存储过程的性能提高了2倍以上,而如果与使用 MySQL 代理相比,性能会提高到3倍。