MySQL存储过程、函数和游标

时间:2022-05-31 09:05:47

这里我新建了两个表,一个users和test

 CREATE TABLE users(
username varchar(20),
pwd varchar(30)
);
CREATE TABLE test(
id INT,
username VARCHAR(20)
)

MySQL存储过程、函数和游标

这里向users表中插入了多条数据,主要是为了测试存储过程和游标的使用

1.不带参数的存储过程,从users表中查出所有数据

 BEGIN
SELECT * FROM users;
END

结果和上图一样

2.带参数的存储过程

 BEGIN
SELECT * FROM users WHERE pwd=name_in;
END

这里根据传入的pwd不同结果集不同

3.函数

 RETURN (SELECT users.pwd FROM users WHERE users.username = 'gxf')

下面是游标的使用

这里新建了一个存储过程,并在存储过程中使用游标遍历users表,在遍历的时候向test表中插入一条数据,(1,username)username来自users表中

 BEGIN
DECLARE TEMP_NAME VARCHAR(20) DEFAULT 'GXF';
DECLARE TEMP_PWD VARCHAR(30) DEFAULT '';
DECLARE DONE INT DEFAULT 0;
DECLARE i INT DEFAULT 10; DECLARE cursor_query CURSOR FOR SELECT * FROM users;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET DONE = 1; OPEN cursor_query; myLoop : LOOP
FETCH cursor_query INTO TEMP_NAME, TEMP_PWD;
IF DONE = 1 THEN
LEAVE myLoop;
END IF; INSERT INTO test VALUES(1, TEMP_NAME); END LOOP myLoop; CLOSE cursor_query;
END

通过调用使用游标的存储过程后,查询test表

 CALL DATA_QUERY_CURSOR;
SELECT * FROM test;

test表中的记录为

MySQL存储过程、函数和游标