mysql存储过程之游标遍历数据表

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 原文:mysql存储过程之游标遍历数据表今天写一个mysql存储过程,根据自己的需求要遍历一个数据表,因为对存储过程用的不多,语法不甚熟悉,加之存储过程没有调试环境,花了不少时间才慢慢弄好,故留个痕迹。
+关注继续查看
原文:mysql存储过程之游标遍历数据表

今天写一个mysql存储过程,根据自己的需求要遍历一个数据表,因为对存储过程用的不多,语法不甚熟悉,加之存储过程没有调试环境,花了不少时间才慢慢弄好,故留个痕迹。

 1  BEGIN
 2      DECLARE Done INT DEFAULT 0;
 3     
 4      DECLARE CurrentLingQi INT;
 5     
 6      DECLARE ShizuName VARCHAR(30);
 7      /* 声明游标 */
 8      DECLARE rs CURSOR FOR SELECT NodeName, LingQi FROM socialrelation;
 9      /* 异常处理 */
10      DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET Done = 1;
11     
12      /* 打开游标 */
13      OPEN rs;  
14     
15      /* 逐个取出当前记录LingQi字段的值,需要进行最大值的判断 */
16      FETCH NEXT FROM rs INTO ShizuName, CurrentLingQi;     
17      /* 遍历数据表 */
18      REPEAT
19            IF NOT Done THEN
20               SET CurrentLingQi = CurrentLingQi + 60;
21               /* 如果更新后灵气值大于允许的最大值,则就设置为最大值 */
22               IF CurrentLingQi >= 1800 THEN
23                  UPDATE socialrelation SET LingQi = 1800 WHERE NodeName = ShizuName;
24               ELSE
25               /* 否则,正常更新 */
26                  UPDATE socialrelation SET LingQi = LingQi + 60 WHERE NodeName = ShizuName;
27               END IF;
28            END IF;
29           
30      FETCH NEXT FROM rs INTO ShizuName, CurrentLingQi;
31 
32      UNTIL Done END REPEAT;
33     
34      /* 关闭游标 */
35      CLOSE rs;
36 END

 

  

今天写一个mysql存储过程,根据自己的需求要遍历一个数据表,因为对存储过程用的不多,语法不甚熟悉,加之存储过程没有调试环境,花了不少时间才慢慢弄好,故留个痕迹。

 

 

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
2月前
|
关系型数据库 MySQL
认识MySQL数据表的浮点数类型
认识MySQL数据表的浮点数类型。
69 0
|
3月前
|
SQL 关系型数据库 MySQL
MySQL数据表高级操作
MySQL数据表高级操作
33 1
|
3月前
|
存储 关系型数据库 MySQL
MySQL的约束类型、数据库操作、数据表操作大全(简述)
MySQL的约束类型、数据库操作、数据表操作大全(简述)
46 0
|
3月前
|
关系型数据库 MySQL 数据库
MySQL数据表:对数据的基础操作(增、删、查、改)以及运算符的讲解
MySQL数据表:对数据的基础操作(增、删、查、改)以及运算符的讲解
53 1
|
3月前
|
SQL 关系型数据库 MySQL
MySQL数据表的结构的同步练习与实训
进行MySQL数据表的结构的同步练习与实训。
75 0
|
3月前
|
存储 关系型数据库 MySQL
mysql添加或删除表以及给数据表添加或删除列
mysql添加或删除表以及给数据表添加或删除列
59 1
|
4月前
|
SQL 关系型数据库 MySQL
MySQL数据表操作
MySQL是一种关系型数据库,它使用SQL (Structured Query Language)来管理和操作数据库中的数据。以下是MySQL中的一些常见的数据表操作:
71 0
|
4月前
|
SQL 关系型数据库 MySQL
MySQL SELECT:数据表查询语句
MySQL SELECT:数据表查询语句
56 0
|
4月前
|
SQL 存储 关系型数据库
MySQL修改数据表(ALTER TABLE语句)
MySQL修改数据表(ALTER TABLE语句)
77 0
|
4月前
|
SQL 存储 关系型数据库
MySQL创建数据表(CREATE TABLE语句)
MySQL创建数据表(CREATE TABLE语句)
294 0
推荐文章
更多