理解MySQL中的游标
最编程
2024-01-22 21:41:27
...
delimiter //
create procedure i_a1 ( in b int )
begin
declare a int;
set a=1;
while a <= b
do
insert into a1 values ( a, concat(a,'x'));
set a=a+1;
end while;
end;
//
delimiter ;
create table a2 ( id int , name varchar(10) );
目标, 传输 a1 表数据到 a2 表
delimiter //
create procedure test23 ( in a int )
begin
declare b int;
declare c varchar(10);
declare d int;
declare c1 cursor for select * from new.a1;
open c1;
set d=1;
repeat
fetch c1 into b,c;
insert into a2 values (b,c);
set b=b+1;
until a < b
end repeat;
close c1;
end;
//
delimiter ;
ERROR 1329 (02000): No data - zero rows fetched, selected, or processed
ERROR 1326 (24000): Cursor is not open <- 没有打开游标错误 ->
declare xx handler -- 必须在 cursor 后定义, 不能够有 ; --
delimiter //
create procedure test24 ( in a int )
begin
declare b int;
declare c varchar(10);
declare d int;
declare c1 cursor for select * from new.a1;
declare exit handler for not found
begin end;
declare exit handler for 1326
begin end;
open c1;
set d=1;
repeat
fetch c1 into b,c;
insert into a2 values (b,c);
set b=b+1;
until a < b
end repeat;
close c1;
end;
//
delimiter ;
下面游标用于更新 name, addr 列
-- 注意: 5.0 中游标具有只读性, 无法自行更新, 5.1.26 测试能够更新游标所在行 --
delimiter //
create procedure test25 ( in a int )
begin
declare b int;
declare c varchar(10);
declare c1 cursor for select name from new.a1;
open c1;
set b=1;
repeat
fetch c1 into c;
update a1 set name=concat('u',c) where id=b;
update a1 set addr=concat(a,c) where id=b;
set b=b+1;
until a < b
end repeat;
close c1;
end;
//
delimiter ;
上一篇: 玩转MySQL游标:语法、定义和使用详解
下一篇: 使用MySQL游标进行循环遍历的技巧
推荐阅读
-
mysql 中 bigint、int、mediumint、smallint 和 tinyint 的范围
-
[MySQL] MySQL中的原子更新操作:如何模拟 MongoDB 的 "find_one_and_update
-
解释 MySql InnoDB 中的三种行锁(记录锁、间隙锁和专业键锁)
-
微信 "扫一扫 "物联网,全面揭秘 "扫一扫 "背后的扫盲技术!-1.1 扫一扫感知物体是做什么的? 1.1 微信扫一扫是做什么的? 扫一扫识物是指以图片或视频(商品图片:鞋/包/美妆/服饰/家电/玩具/图书/食品/珠宝/家具/其他商品)为输入媒介,挖掘微信内容生态中的有价值信息(电商+百科+资讯,如图1所示),并展示给用户。这里的电商基本涵盖了微信小程序覆盖上亿SKU的全量优质电商,可以支持用户货比N家并直接下单购买,百科和资讯则聚合了微信内的头部自媒体如搜狗、搜搜、百度等,向用户展示和分享拍摄商品相关的内容资讯。 图 1 扫一扫识别功能示意图 欢迎大家更新iOS新版微信→扫一扫→识货,亲自体验,也欢迎大家通过识货界面的反馈按钮向我们提交反馈意见。 扫一扫识物实景图展示 1.2 扫一扫识物有哪些使用场景? 扫一扫识物的目的是为用户访问微信内部生态内容开辟一个新窗口,以用户扫图片为输入形式,为用户提供微信生态内容中的百科、资讯、电商等作为展示页面。除了用户熟悉的扫一扫操作外,我们还将进一步拓展长按操作,让用户更方便地进行扫一扫操作。"扫一扫知事 "的落地场景主要涵盖三大部分: a. 科普知识: a.科普知识。用户通过扫一扫,可以在微信生态圈中获取该对象的百科、资讯等常识或趣闻,帮助用户更好地了解该对象; b.购物场景。同样的搜索功能支持用户看到喜欢的商品立即检索到微信小程序电商中的同款商品,支持用户即扫即购; c.广告场景。扫一扫识别物体可以辅助公众号文章、视频更好地理解其中蕴含的图片信息,从而更好地投放匹配广告,提高点击率。 1.3 Sweep Sense 为 Sweep 家族带来了哪些新技术? 对于扫一扫来说,大家耳熟能详的应该就是扫一扫二维码、扫一扫小程序码、扫一扫条形码、扫一扫翻译了。无论是各种形式的编码还是文字字符,都可以看作是图片的一种特定编码形式,而物的识别则是对自然场景图片的识别,这对于扫一扫家族来说是一个质的飞跃,我们希望从物的识别入手,进一步拓展扫一扫对自然场景图片的理解能力,比如扫酒、扫车、扫植物、扫人脸等服务,如下图3所示。 图 3 Sweep 家族
-
Java面试 "带你一次性了解面试中的必要问题,谈谈你对ES的理解。
-
Mysql 中数据类型括号中数字的含义
-
(访谈)MySQL中INT(5)和VARCHAR(20)中括号内的数字是什么意思,以及VARCHAR和CHAR的区别
-
XAML 中的 Material Design 如何理解 DialogHost
-
Mysql/Oracle/Damon 中的数据字典表
-
问 如何使 ABAP 将"_"理解为 BODS 全局变量值中的特殊字符?