目录
一、概念
根据某种需求提前写好的SQL语句集合,需要用到时调用这块集合
二、创建存储过程和调用方法
2.1创建存储过程语句
小写版
大写版
2.2调用方法
调用存储过程语句
2.3参数详情
以下在创建的过程中使用DELIMITER $开始,DELIMITER ;结束,是因为mysql是以;结束的,此处创建存储过程的时候需要指定结尾符号为$,整个存储过程执行完成后,再还原为mysql的结束符;即可
DELIMITER $
		    CREATE PROCEDURE test1()
		BEGIN
			INSERT INTO admin(username,`password`) VALUES ('JOHN1','000001');
			INSERT INTO admin(username,`password`) VALUES ('JOHN2','000002');
			INSERT INTO admin(username,`password`) VALUES ('JOHN3','000003');
			INSERT INTO admin(username,`password`) VALUES ('JOHN4','000004');
			INSERT INTO admin(username,`password`) VALUES ('JOHN5','000005');
		END $ 
调用
call test1() 
2.4 入参存储过程
多个参数中间用逗号隔开
DELIMITER $
		CREATE PROCEDURE testParams(IN username varchar(20),IN password varchar(20))
		BEGIN
			DECLARE RESULT VARCHAR(20) DEFAULT '';#申明并初始化
			select COUNT(1) INTO RESULT #赋值将统计到的count(1) 赋值给RESULT结果 
			from  admin
			where admin.username=username #如果参数名相同的话指明参数是那个表的字段即可
				and admin.password=password;
		END $
		DELIMITER ; 
调用
call testParams('11','22'); 
2.5出参存储过程
DELIMITER $
		CREATE PROCEDURE myp7(IN beautyName varchar(20),OUT boyName VARCHAR(20),OUT userCP varchar(20))
		BEGIN
			SELECT bo.boyName,bo.userCP INTO boyName,userCP #此处赋值的时候多个直接INTO为对应位置的出参对象即可
			FROM boys bo
				INNER JOIN beauty b on bo.id=b.boyfriend_id
			WHERE
				b.name=beautyName;
		END $
		DELIMITER ; 
调用
CALL myp7('小昭',@boyName,@userCP); 
#此处存储过程的两个入参(也即出参)用@符号定义即可,也可以先定义好传入到里面
SELECT @boyName AS boyName,@userCP as userCP #查询存储过程运行的结果 
2.6带有INOUT的存储过程
		DELIMITER $
			CREATE PROCEDURE ccgc(INOUT a int,INOUT b int)
			BEGIN
				SET a=a*2;
				SET b=b*2;
			END $
		DELIMITER ; 
调用
###此处需要提前定义参数值,类似于java的入参,
		SET @m=10;
		SET @n=30;
		call ccgc(@m,@n);
		#然后调用,并打印输出
		select @m,@n








