mysql批量更新数据,即:循环select记录然后更新某一字段
2018-02-26 14:21
435 查看
/*判断是否存在,如果存在就删除*/
drop procedure if exists tempProcedure_Test;/*取一个系统中绝对不会用到的存储过程名称*/
/*创建临时存储过程*/
create procedure tempProcedure_Test()
BEGIN
declare isDone int default 0; /*判断是否还有记录*/
declare intNumber int default 30000;/*用于自增的变量*/
declare tempId char(36); /*每条记录循环时的临时ID*/
declare folderIds cursor for select A.ID from mus_gateway_deduct_transaction as A;/*取出来所有需要循环的数据*/
declare continue handler for not FOUND set isDone = 1;/*如果不存在就设置为1,即为true*/
open folderIds; /*OPEN*/
REPEAT /*开始循环数据*/
fetch folderIds into tempId;
if not isDone THEN
update mus_gateway_deduct_transaction set id=intNumber where id=tempId;
set intNumber=intNumber+1;
end if;
until isDone end repeat;
close folderIds; /*CLOSE,对应上面的open folderIds;*/
END;
call tempProcedure_Test();/*调用下这个临时的存储过程*/
drop procedure tempProcedure_Test; /*使用完毕后要删除垃圾*/
drop procedure if exists tempProcedure_Test;/*取一个系统中绝对不会用到的存储过程名称*/
/*创建临时存储过程*/
create procedure tempProcedure_Test()
BEGIN
declare isDone int default 0; /*判断是否还有记录*/
declare intNumber int default 30000;/*用于自增的变量*/
declare tempId char(36); /*每条记录循环时的临时ID*/
declare folderIds cursor for select A.ID from mus_gateway_deduct_transaction as A;/*取出来所有需要循环的数据*/
declare continue handler for not FOUND set isDone = 1;/*如果不存在就设置为1,即为true*/
open folderIds; /*OPEN*/
REPEAT /*开始循环数据*/
fetch folderIds into tempId;
if not isDone THEN
update mus_gateway_deduct_transaction set id=intNumber where id=tempId;
set intNumber=intNumber+1;
end if;
until isDone end repeat;
close folderIds; /*CLOSE,对应上面的open folderIds;*/
END;
call tempProcedure_Test();/*调用下这个临时的存储过程*/
drop procedure tempProcedure_Test; /*使用完毕后要删除垃圾*/
相关文章推荐
- select得到结果集,然后循环更新另一张表
- sql 如何提取某一字段记录的部分数据
- mysql批量更新数据库的某一个字段
- mysql批量更新多条记录的同一个字段为不同值的方法
- mysql批量更新多条记录的同一字段为不同值
- sql删除某一字段的重复记录(500万条数据以上)
- 随即读取B表数据,然后随即更新到A表字段
- 循环得到一条记录中每个字段里的数据
- 按某一字段分组取最大(小)值所在行的数据,如何按字段删除重复记录
- Oracle存储过程游标循环更新新增字段处理线上历史数据问题
- thinkphp3.2 更新数据表某一字段的全部内容
- Oracle 删除重复数据只留一条 查询及删除重复记录的SQL语句 1、查找表中多余的重复记录,重复记录是根据单个字段(Id)来判断 select * from 表 wher
- Oracle中将一个表中某一字段的数据更新到另一个表中某一字段
- mysql批量更新多条记录的同一个字段为不同值的方法
- mysql 插入数据,若存在则更新某一字段
- 新增字段不为空默认值,然后关更新数据
- 同一张表,合并某相同字段,然后提取某一字段数据
- mysql 根据select内容批量更新数据
- mysql 根据select内容批量更新数据
- orcle,mysql 更新备注 某字段数据追加函数