MySQL使用游标数据实例教程
技术百科
巴扎黑
发布时间:2017-05-18
浏览: 次 使用游标数据
在一个游标被打开后,可以使用 FETCH 语句分别访问它的每一行。FETCH 指定检索什么数据(所需的列),检索出来的数据存储在什么地方。它还向前移动游标中的内部行指针,使下一条 FETCH 语句检索下一行(不重复读取同一行)。
第一个例子从游标中检索单个行(第一行):
输入:
create procedure processorders() BEGIN -- declare local variables declare o int; -- declare the cursor declare ordernumbers cursor for select order_num from orders: -- open the cursor open ordernumbers; -- get order number fetch ordernumbers into o; -- close the cursor close ordernumbers; end;
分析:其中 FETCH 用来检索当前行的 order_num 列(将自动从第一行开始)到一个名为 o 的局部声明的变量中。对检索出的数据不做任何处理。
在下一个例子中,循环检索数据,从第一行到最后一行:
输入:
create procedure processorders() BEGIN -- declare local variables declare done boolean default 0; declare o int; -- declare the cursor declare ordernumbers cursor for select order_num from orders: --declare continue handler declare continue handler for sqlstate '02000' set done = 1; -- open the cursor open ordernumbers; --loop through all rows repeat -- get order number fetch ordernumbers into o; -- end of loop until done end repeat; -- close the cursor close ordernumbers; end;
分析:与前一个例子一样,这个例子使用 FETCH 检索当前 order_num到声明的名为 o 的变量中。但与前一个例子不一样的是,这个例子中的 FETCH 是在 REPEAT 内,因此它反复执行直到 done 为真(由 UNTILdone END REPEAT; 规定)。为使它起作用,用一个 DEFAULT 0 (假,不结束)定义变量 done 。那么, done 怎样才能在结束时被设置为真呢?答案是用以下语句:
declare continue handler for sqlstate '02000' set done = 1;
这条语句定义了一个 CONTINUE HANDLER ,它是在条件出现时被执行的代码。这里,它指出当 SQLSTATE '02000' 出现时, SET done=1。SQLSTATE '02000' 是一个未找到条件,当 REPEAT 由于没有更多的行供循环而不能继续时,出现这个条件。
MySQL的错误代码 关于MySQL 5使用的MySQL错误代码列表,请参阅http://dev.mysql.com/doc/mysql/en/error-handling.html。
DECLARE 语句的次序 DECLARE 语句的发布存在特定的次序。用 DECLARE 语句定义的局部变量必须在定义任意游标或句柄之前定义,而句柄必须在游标之后定义。不遵守此顺序将产生错误消息。
如果调用这个存储过程,它将定义几个变量和一个 CONTINUE HANDLER ,定义并打开一个游标,重复读取所有行,然后关闭游标。如果一切正常,你可以在循环内放入任意需要的处理(在 FETCH 语句之后,循环结束之前)。
重复或循环? 除这里使用的 REPEAT 语句外,MySQL还支持循环语句,它可用来重复执行代码,直到使用 LEAVE 语句手动退出为止。通常 REPEAT 语句的语法使它更适合于对游标进行循环。
为了把这些内容组织起来,下面给出我们的游标存储过程样例的更进一步修改的版本,这次对取出的数据进行某种实际的处理:
输入:
create procedure processorders() BEGIN -- declare local variables declare done boolean default 0; declare o int; declare t decimal(8,2); -- declare the cursor declare ordernumbers cursor for select order_num from orders; -- declare continue handler declare continue handler for sqlstate '02000' set done = 1; -- create a table to store the results create table if not exists ordertotals (order_num int, total decimal(8,2)); -- open the cursor open ordernumbers; -- loop through all rows repeat -- get order number fetch ordernumbers into o; -- get the total for this order call ordertotal(o,1,t); -- insert order and total into ordertotals insert into ordertotals(order_num,total) values(o,t); -- end of loop until done end repeat; -- close the cursor close ordernumbers; END;
分析:在这个例子中,我们增加了另一个名为 t 的变量(存储每个订单的合计)。此存储过程还在运行中创建了一个新表(如果它不存在的话),名为 ordertotals 。这个表将保存存储过程生成的结果。 FETCH像以前一样取每个 order_num ,然后用 CALL 执行另一个存储过程(我们在前一章中创建)来计算每个订单的带税的合计(结果存储到 t )。最后,用 INSERT 保存每个订单的订单号和合计。
此存储过程不返回数据,但它能够创建和填充另一个表,可以用一条简单的 SELECT 语句查看该表:
输入:
select * from ordertotals;
输出:
这样,我们就得到了存储过程、游标、逐行处理以及存储过程调用其他存储过程的一个完整的工作样例
。
# 是在
# 的是
# 是一个
# 几个
# 样例
# 错误代码
# mysql
# 句柄
# 使它
# 现时
# 存储过程
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- php高频调试功能有哪些_php常用调试函数与工具
- windows如何备份注册表_windows导出和
- c++中的Tag Dispatching是什么_c
- Windows家庭版如何开启组策略(gpedit.
- 用lighttpd能运行php吗_lighttpd
- Python正则表达式实战_模式匹配说明【教程】
- Python lxml的etree和Element
- php8.4如何调用com组件_php8.4win
- Win11文件夹预览图不显示怎么办_Win11缩略
- 如何使用Golang template生成文本模板
- Win11怎么开启HDR模式_Windows 11
- c++如何用AFL++进行模糊测试 c++ Fuz
- Win11讲述人怎么关闭_Win11误触开启语音朗
- php查询数据怎么导出csv_查询结果转csv文件
- php订单日志怎么记录发货_php记录订单发货操作
- ACF 教程:如何正确更新嵌套在多层 Group
- Win11怎么设置按流量计费_Win11限制后台流
- Python装饰器设计思路_功能增强机制说明【指导
- Win11怎么用设置清理回收站_Win11设置清理
- Windows系统时间服务错误_W32Time服务
- Django 测试数据库表缺失与字段未创建问题的完
- VSC怎样在VSC中调试PHPAPI_接口调试技巧
- windows系统如何安装cab更新补丁_wind
- 如何在 Go 中创建包含 map 的 slice(
- Python类装饰器使用_元编程解析【教程】
- Windows怎样关闭桌面弹窗广告_Windows
- MAC如何设置网卡MAC地址克隆_MAC终端修改物
- c++中的CRTP是什么 c++奇异递归模板模式【
- 短链接还原php提示内存不足_调整PHP内存限制设
- Win11怎么开启空间音效_Windows11耳机
- 如何使用Golang实现容器安全扫描_Golang
- Windows如何拦截腾讯视频广告_Windows
- 企业SEO优化选择网站建设模板的技巧
- php8.4xdebug无法调试怎么办_php8.
- c++的位运算怎么用 与、或、异或、移位操作详解【
- Python文件和流处理指南_高效读写大体积数据文
- Win10怎么设置开机密码_Windows10账户
- Windows10任务栏图标变成白色文件_Win1
- Win11怎么关闭任务栏小图标_Windows11
- Win11怎么开启游戏模式_Windows11优化
- Windows音频驱动无声音原因解析_声卡驱动错误
- Windows怎样拦截QQ浏览器广告_Window
- 如何在 Python 中将 ISO 8601 时间
- Windows 10怎么录屏_Windows 10
- Python高性能计算项目教程_NumPyCyth
- 如何使用Golang defer优化性能_减少不必
- Python文件操作优化_大文件与流处理解析【教程
- Win11怎么设置单手模式_Win11触控键盘布局
- Python异步网络编程_aiohttp说明【指导
- Win11怎么查看显卡显存_查询Win11显卡详细

QQ客服