这里我新建了两个表,一个users和test
CREATE TABLE users(
username varchar(20),
pwd varchar(30)
);
CREATE TABLE test(
id INT,
username VARCHAR(20)
)
这里向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表中的记录为