在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格式输出,在线求教。。。。。

大神们,帮我看看吧。。。
展开
 我来答
djc11281
2014-09-18 · 超过28用户采纳过TA的回答
知道答主
回答量:63
采纳率:0%
帮助的人:38.8万
展开全部
 
    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是存储过程通过传参传过来的,不是事先就确定了的。那该怎么办 ?
追答
跟参数传进来有什么关系?
今至电子科技有限公司
2024-08-23 广告
数据库备份是确保数据安全与业务连续性的关键环节。我们上海今至电子科技有限公司高度重视数据保护,定期执行全面的数据库备份策略。这包括使用先进工具和技术,对关键业务数据进行自动化备份,并存储在安全可靠的外部存储介质或云端。通过定期验证备份的完整... 点击进入详情页
本回答由今至电子科技有限公司提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式