mysql批量更新存储过程怎么写

 我来答
敏敏的自媒体
2016-04-24 · 知道合伙人互联网行家
敏敏的自媒体
知道合伙人互联网行家
采纳数:16780 获赞数:25041
世赫工业核心工程师

向TA提问 私信TA
展开全部
create procedure batchUpdate(in n int)  
begin  
declare inParam int default n;  
declare i int default 1;  
declare id int;  
declare username varchar(255);  
declare integral varchar(255);  
declare ranking int;  
declare _resultSet cursor for select a.id, a.username,a.integral,a.ranking from user a order by a.integral desc limit inParam;  
open _resultSet;  
while i <= inParam do  
fetch _resultSet into id, username, integral,ranking;  
update user a set a.ranking = i where a.id = id;  
set i = i +1;  
end while;  
close _resultSet;  
end;  
  
mysql> select * from user;  
+----+----------+----------+---------+  
| id | username | integral | ranking |  
+----+----------+----------+---------+  
|  1 | abc      |        1 |       0 |  
|  2 | abc      |        2 |       0 |  
|  3 | abc      |        3 |       0 |  
|  4 | abc      |        4 |       0 |  
|  5 | abc      |        5 |       0 |  
|  6 | abc      |        6 |       0 |  
|  7 | abc      |        7 |       0 |  
|  8 | abc      |        8 |       0 |  
|  9 | abc      |        9 |       0 |  
| 10 | abc      |       10 |       0 |  
| 11 | abc      |       11 |       0 |  
| 12 | abc      |       12 |       0 |  
| 13 | abc      |       13 |       0 |  
| 14 | abc      |       14 |       0 |  
+----+----------+----------+---------+  
14 rows in set  
  
mysql> call batchUpdate(14);  
Query OK, 1 row affected  
  
mysql> select * from user;  
+----+----------+----------+---------+  
| id | username | integral | ranking |  
+----+----------+----------+---------+  
|  1 | abc      |        1 |      14 |  
|  2 | abc      |        2 |      13 |  
|  3 | abc      |        3 |      12 |  
|  4 | abc      |        4 |      11 |  
|  5 | abc      |        5 |      10 |  
|  6 | abc      |        6 |       9 |  
|  7 | abc      |        7 |       8 |  
|  8 | abc      |        8 |       7 |  
|  9 | abc      |        9 |       6 |  
| 10 | abc      |       10 |       5 |  
| 11 | abc      |       11 |       4 |  
| 12 | abc      |       12 |       3 |  
| 13 | abc      |       13 |       2 |  
| 14 | abc      |       14 |       1 |  
+----+----------+----------+---------+  
14 rows in set
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
今至电子科技有限公司
2024-08-23 广告
数据库备份是确保数据安全与业务连续性的关键环节。我们上海今至电子科技有限公司高度重视数据保护,定期执行全面的数据库备份策略。这包括使用先进工具和技术,对关键业务数据进行自动化备份,并存储在安全可靠的外部存储介质或云端。通过定期验证备份的完整... 点击进入详情页
本回答由今至电子科技有限公司提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式