大家好: 进来需要将前端SQL转入后台变为存储过程,如何在Java程序中获得存储过程的结果集?是否一定要用游标,希望大家能写个小例子,多谢了。
解决方案 »
- 如何查询1986年出生的职员
- 怎样实现这样的行列转置?
- 关于mysql插入“—”这个符号后,就报错的问题。[
- 有没有将varchar转换为double的函数?
- 各位大侠帮帮忙!
- ID从1000-2000的表都update为200-300的随机数 该怎么写啊?
- 请教一个MYSQL查询的问题,感谢关注的朋友:)
- mysql的where条件过滤时是先执行前面的判断语句还是后面的判断语句!
- 用Mysql用什么软件管理好呀?就是可视化的那种哈,求大神们推荐一下哈!哪个软件最好用哈!我的Mysql版本是5.5的哈!在线等大神解答哈!
- mysql 多表查询 1700+条数据查询1700+次 需要20多分钟,怎么可以优化一下
- slow_query_log_file存储名字问题
- 那位高手来给我解决一下【没有什么分,只是希望大家能从技术的角度帮我】
use `test`$$
drop procedure if exists `proc_cursor_t`$$
use `test`$$CREATE PROCEDURE `proc_cursor_t`(p_code varchar(30), p_cumu int)
SQL SECURITY INVOKER
begin
declare _done int default 0;
declare v_flag tinyint default 0;
declare v_item_id int default 0;
declare v_item_code varchar(20) default '';
declare cur_code cursor for
select '0001' item_id, '0002' item_code union all
select '1001' item_id, '1002' item_code union all
select '2001' item_id, '2002' item_code union all
select '3001' item_id, '3002' item_code union all
select '4001' item_id, '4002' item_code ;
declare continue handler for not found
begin
set _done=1;
select 'not found';
commit;
end;
-- handler exception
declare exit handler for sqlexception
begin
-- 异常处理
select 'exception';
end;
-- 打开游标
open cur_code;
allcodes:loop
-- 开始遍历游标
fetch cur_code into v_item_id, v_item_code;
if not _done then
-- 开始业务操作
if p_cumu = 2 then
select 'cumu 2', v_item_id, v_item_code,now();
else
select 'cumu 1', v_item_id, v_item_code,now();
end if;
else
leave allcodes;
end if;
end loop allcodes;
-- 关闭游标
close cur_code;
end
存储过程的返回值,用call sp(@A);select @A;这样获取。