在MySql数据库中实现一个存储过程,在这个存储过程中,需要用游标,动态SQL,详情点击查看。。。 70
dropprocedureifEXISTStest;delimiter//CREATEPROCEDUREtest(inidint,outjsonVARCHAR(500))...
drop procedure if EXISTS test;
delimiter //
CREATE PROCEDURE test (in id int,out json VARCHAR(500))
BEGIN
declare done INTEGER default 0;
declare abc varchar(20) default 'select stu_name from student';
DECLARE cursor_test CURSOR for abc;
-- DECLARE cursor_test CURSOR for select stu_name from student;
declare continue handler for not found set @done = 1;
OPEN cursor_test;
repeat
FETCH cursor_test into stu_id,stu_name,stu_age;
BEGIN
set json = CONCAT(json,',',stu_name);
end;
UNTIL @done = 1;
END repeat;
close cursor_test;
end;
我想实现在一个存储过程中,可以实现,将传入的id合并到sql语句中,然后,用游标一条一条读出来,最后返回json格式的字符串。
例如,我在程序中 call test(12,json),
通过调用存储过程test,执行 select stu_name from student where id = 12.然后通过游标将结果用json格式输出,在线求教。。。。。
大神们,帮我看看吧。。。 展开
delimiter //
CREATE PROCEDURE test (in id int,out json VARCHAR(500))
BEGIN
declare done INTEGER default 0;
declare abc varchar(20) default 'select stu_name from student';
DECLARE cursor_test CURSOR for abc;
-- DECLARE cursor_test CURSOR for select stu_name from student;
declare continue handler for not found set @done = 1;
OPEN cursor_test;
repeat
FETCH cursor_test into stu_id,stu_name,stu_age;
BEGIN
set json = CONCAT(json,',',stu_name);
end;
UNTIL @done = 1;
END repeat;
close cursor_test;
end;
我想实现在一个存储过程中,可以实现,将传入的id合并到sql语句中,然后,用游标一条一条读出来,最后返回json格式的字符串。
例如,我在程序中 call test(12,json),
通过调用存储过程test,执行 select stu_name from student where id = 12.然后通过游标将结果用json格式输出,在线求教。。。。。
大神们,帮我看看吧。。。 展开
1个回答
展开全部
DECLARE stuName VARCHAR(50);
DECLARE flag INT;
DECLARE update_cursor CURSOR
FOR
SELECT stu_name FROM student WHERE id = id;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET flag=1;
SET flag=0;
OPEN update_cursor;
REPEAT /*循环*/
FETCH update_cursor INTO stuName;
SET json = CONCAT(json,',',stuName);
UNTIL flag
END REPEAT;
CLOSE update_cursor ;
更多追问追答
追问
非常感谢你的回答。
SELECT stu_name FROM student WHERE id = id;
关键我这个id是存储过程通过传参传过来的,不是事先就确定了的。那该怎么办 ?
追答
跟参数传进来有什么关系?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询