mysql存储过程在动态SQL内获取返回值

时间:2022-01-31 09:42:39

不需要使用游标循环来读取,直接select * into @变量就OK了,还可以传递参数来执行。 
1
mysql存储过程在动态SQL内获取返回值MySql通用分页存储过程
2mysql存储过程在动态SQL内获取返回值
3mysql存储过程在动态SQL内获取返回值过程参数
4mysql存储过程在动态SQL内获取返回值p_cloumns varchar(500),p_tables varchar(100),p_where varchar(4000),p_order varchar(100),p_pageindex int,p_pagesize int,out p_recordcount int,out p_pagecount int
5mysql存储过程在动态SQL内获取返回值
6mysql存储过程在动态SQL内获取返回值$$:begin
7mysql存储过程在动态SQL内获取返回值declare v_sqlcounts varchar(4000);
8mysql存储过程在动态SQL内获取返回值declare v_sqlselect varchar(4000);
9mysql存储过程在动态SQL内获取返回值 #拼接查询总记录的SQL语句
10mysql存储过程在动态SQL内获取返回值set v_sqlcounts = concat('select count(*) into @recordcount from ',p_tables,p_where);
11mysql存储过程在动态SQL内获取返回值 #select v_sqlcounts;leave $$;
12mysql存储过程在动态SQL内获取返回值set @sqlcounts = v_sqlcounts;
13mysql存储过程在动态SQL内获取返回值prepare stmt from @sqlcounts;
14mysql存储过程在动态SQL内获取返回值execute stmt;
15mysql存储过程在动态SQL内获取返回值deallocate prepare stmt;
16mysql存储过程在动态SQL内获取返回值 #获取动态SQL语句返回值
17mysql存储过程在动态SQL内获取返回值set p_recordcount = @recordcount;
18mysql存储过程在动态SQL内获取返回值 #根据总记录跳数计算出总页数
19mysql存储过程在动态SQL内获取返回值set p_pagecount = ceiling((p_recordcount+0.0)/p_pagesize);
20mysql存储过程在动态SQL内获取返回值if p_pageindex <1 then
21mysql存储过程在动态SQL内获取返回值set p_pageindex = 1;
22mysql存储过程在动态SQL内获取返回值 elseif p_pageindex > p_pagecount and p_pagecount <> 0 then
23mysql存储过程在动态SQL内获取返回值set p_pageindex = p_pagecount;
24mysql存储过程在动态SQL内获取返回值end if;
25mysql存储过程在动态SQL内获取返回值 #拼接分页查询记录的动态SQL语句
26mysql存储过程在动态SQL内获取返回值set v_sqlselect = concat('select ',p_cloumns,' from ',p_tables,p_where,if(p_order is not null,p_order,''),' limit ',(p_pageindex-1)*p_pagesize,' , ',p_pagesize);
27mysql存储过程在动态SQL内获取返回值 #select v_sqlselect;leave $$;
28mysql存储过程在动态SQL内获取返回值set @sqlselect = v_sqlselect;
29mysql存储过程在动态SQL内获取返回值prepare stmtselect from @sqlselect;
30mysql存储过程在动态SQL内获取返回值execute stmtselect;
31mysql存储过程在动态SQL内获取返回值deallocate prepare stmtselect;
32mysql存储过程在动态SQL内获取返回值end $$