什么是存储过程
SQL语句需要先编译然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给定参数(如果该存储过程带有参数)来调用执行它。
存储过程语法
CREATE PROCEDURE 过程名([[IN|OUT|INOUT] 参数名 数据类型[,[IN|OUT|INOUT] 参数名 数据类型…]]) [特性 ...] 过程体
DELIMITER //
CREATE PROCEDURE myproc(OUT s int)
BEGIN
SELECT COUNT(*) INTO s FROM students;
SELECT COUNT(*) INTO s FROM students;
SELECT COUNT(*) INTO s FROM students;
END
//
DELIMITER ;
MySQL默认以";"为分隔符,如果没有声明分割符,则编译器会把存储过程当成SQL语句进行处理,因此编译过程会报错,所以要事先用“DELIMITER //”声明当前段分隔符,让编译器把两个"//"之间的内容当做存储过程的代码,不会执行这些代码;“DELIMITER ;”的意为把分隔符还原。
调用方式:call 存储过程名称 - 删除方式:drop procedure 存储过程名
用户变量的传递
存储过程中使用用户变量
create procedure cd1() select concat(@hl,'world');
set @hl='Hello ';
call cd1();
储存过程之间传递用户变量 create procedure cd21() set @name = 'join'; create procedure cd22() select @name; call cd22(); call cd21(); call cd22();
注意:滥用用户变量会导致程序难以理解及管理
参数类型
in:in类型的参数,存储过程中的代码对其进行的修改并不会影响该变量实际的值,属于有去无回 - out:out类型参数,用于输出值,会忽略传入的值。在子程序内部可以对其进行修改。 - inout:该类型数据综合了上述两种类型的特点,可以传入也可以被修改
FOUND_ROWS()和row_count()
FOUND_ROWS():上次查询的结果的行数 - row_count():上次增删改影响的行数 - select last_insert_id():获取上一次自动增长的id
存储过程的好处
执行速度快 - 允许模块化程序设计 - 提高系统的安全性 - 减少网络流量
课后练习
账户【id,用户名,密码,钱数】,日志【id,描述】两个表
写一个存储过程输入参数3个,一个输出参数,用户名,密码,初始金额,用于办卡,生成一条用户名系,并将此记录到日志表中。【1,id:1办卡成功】 - 写一个存储过程参数一个uname,输出参数一个varchar类型,根据该用户的钱数判断,是土豪或者不是【>10000是土豪】,将结果以输出参数的方式传出