1  存储过程简介

存储过程是数据库中为了完成某些复杂功能而设计的一种批量执行sql语句集的结构,编写好这种结构后会编译并存储在数据库服务器中,

调用的时候只需要通过存储过程的名称和参数来执行

2   存储过程的创建

2.1   CREATE  PROCEDURE  存储过程名 (参数列表)

BEGIN
SQL语句代码块
END

下面演示一个简单的例子:

create PROCEDURE test1()
BEGIN
insert into adminuser(username,password) values('agod','3232');
insert into grade(gradename,createdate,course_teacher,master_teacher)  values('098班',null,'afei','vv');
END

调用方式是:call test1()

这个存储过程里插入了两条数据,在实际项目中,这个里面的值必须从外面传进来,下面我们看看存储过程是怎样支持参数的

2.2  存储过程的参数

mysql支持三种类型的参数

类型

说明

IN:输入参数

该值只能传进去,不能返回出来

OUT:输出参数

该值可在内部改变,并返回出来

INOUT:输入输出参数

调用时可以传进去,并且可以返回出来

2.3   存储过程示例

输入参数示例

CREATE PROCEDURE delgrade(IN mygradeid INT)
BEGIN
delete from student where gradeid=mygradeid;
delete from grade where toid=mygradeid;
END

调用:call delgrade(5)

输出参数示例

create PROCEDURE testout(in stuid INT,out sname VARCHAR(20))
BEGIN
select stu.stuname into sname from student as stu where stu.toid=stuid;
END

调用:    

CALL testout(5,@name);
select @name;

3 存储过程语法(声明变量,if和循环)

3.1 声明变量语法:

DECLARE age INT  ;
DECLARE username varchar(20) ;

3.2  if判断的语法:

IF age=100 THEN

SQL语句代码

ELSEIF  age=200 THEN

SQL语句代码

END IF;

3.3 循环LOOP

DROP PROCEDURE IF EXISTS looptest;
CREATE  PROCEDURE looptest()
BEGIN
DECLARE counter int DEFAULT 0;
setcount:LOOP
set counter=counter+1;
IF counter=5 THEN
LEAVE setcount;
END IF;
select counter;
END LOOP setcount;
END;

3.4  循环之while

WHILE counter!= 10 DO
SET counter = counter+1;
END WHILE;

4 .游标

DROP PROCEDURE IF EXISTS cursor_temp;
CREATE PROCEDURE cursor_temp()
BEGIN
DECLARE uname VARCHAR(20);
DECLARE done int;
DECLARE rs_cursor CURSOR
FOR  SELECT au.username from adminuser as au ;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done=1;
OPEN rs_cursor;
cursor_loop:LOOP
FETCH rs_cursor into  uname;
select uname;
IF done=1 THEN
LEAVE cursor_loop;
END IF;
END LOOP cursor_loop;
END;

5 java调用存储过程

5.1,参数传递

CallableStatement cs=conn.prepareCall("{call delgrade(?)}");
cs.setInt(1,4);
cs.executeUpdate();

5.2   输出参数

CallableStatement cs=conn.prepareCall("{call outtest(?,?)}");
cs.registerOutParameter(1,Types.VARCHAR);
cs.setInt(2,5);
cs.executeUpdate();
String uname=cs.getString(1);
System.out.println(uname);
DROP PROCEDURE IF EXISTS insertProce; create PROCEDURE insertProce(delid INT) BEGIN    INSERT INTO grade  VALUES(7,'0912班','2013-12-5 10:10:53','afei','vv');    DELETE FROM adminuser where toid=delid;     END ; CALL insertProce(4); DROP PROCEDURE IF EXISTS findUname ; CREATE PROCEDURE  findUname(IN userid INT,OUT uname VARCHAR(20)) BEGIN    select au.username INTO uname  from adminuser as  au where au.toid=userid; END ; CALL findUname(2,@myuname); select @myuname; DROP PROCEDURE IF EXISTS insertProce; create PROCEDURE insertProce(delid INT) BEGIN    INSERT INTO grade  VALUES(7,'0912班','2013-12-5 10:10:53','afei','vv');    DELETE FROM adminuser where toid=delid;     END ; CALL insertProce(4); DROP PROCEDURE IF EXISTS findUname ; CREATE PROCEDURE  findUname(IN userid INT,OUT uname VARCHAR(20)) BEGIN    select au.username INTO uname  from adminuser as  au where au.toid=userid; END ; CALL findUname(2,@myuname); select @myuname; DROP PROCEDURE IF EXISTS insertProce; create PROCEDURE insertProce(delid INT) BEGIN    INSERT INTO grade  VALUES(7,'0912班','2013-12-5 10:10:53','afei','vv');    DELETE FROM adminuser where toid=delid;     END ; CALL insertProce(4); DROP PROCEDURE IF EXISTS findUname ; CREATE PROCEDURE  findUname(IN userid INT,OUT uname VARCHAR(20)) BEGIN    select au.username INTO uname  from adminuser as  au where au.toid=userid; END ; CALL findUname(2,@myuname); select @myuname;