大批量数据,用mysql批量更新数据的四种方法
创始人
2025-01-10 17:05:40
0

建一个测试表

create table users (     id   int auto_increment         primary key,     name varchar(255) null,     age  int          null );

1 replace into 批量更新【谨慎用】

/**   没有就新增,id一样,就修改   特别注意:每列数据都要写上,不然就会设为null,你就惨了  */ replace into users (id,name,age) values (1,'aa',20),(2,'bb',30),(3,'cc',40);  /* 找死 */ replace into users (id,age) values (1,21),(2,31),(3,41);  /* 正确写法 */ replace into users (id,name,age) values (1,'aa',21),(2,'bb',31),(3,'cc',41);

2 insert into ...on duplicate key update批量更新

/**   执行第一次:(首次数据库表中没有数据,正常插入)  */ insert into users (id,name,age) values (1,'aa',20),(2,'bb',30),(3,'cc',40) on duplicate key update age=age+1;  /**   没有就新增,id一样,就修改,age 列都加1  */ insert into users (id) values (1),(2),(3) on duplicate key update age=age+1;  /**   将 name 从 'aa' ,改为 'aa-1',   age加1  */ insert into users (id,name) values (1,'aa-1'),(2,'bb-1'),(3,'cc-1') on duplicate key update name=values(name) ,age=age+1;  /**   将 name 从 ‘aa-1’ 改为 'xiaowang'   age 改为 10 ,以此类推  */ insert into users (id,name,age) values (1,'xiaowang',10),(2,'xiaoming',15),(3,'xiaochen',20) on duplicate key update name=values(name),age=values(age);

3 创建临时表,先更新临时表,然后从临时表中update

/**   创建临时表[session级别的,所以另开个窗口看不见],先更新临时表,然后从临时表中联表update  */ create temporary table users_temp select * from users;  select * from users_temp; /* 修改临时表 */ update users_temp set age=age+1;  /* 修改正式表的记录 set位置,正式表要在前面 */ update users,users_temp set users.age=users_temp.age where users.id=users_temp.id;  drop table users_temp;

4 使用mysql 自带的语句构建批量更新 [数据控制在1w以内]

update users set age=age+1 where id in (1,2,3);  /**   建议将修改记录条数控制在1W左右,不要超过2W,否则会耗费的时间也是成倍增加的  */ update users set name = case id     when 1 then '小刚'     when 2 then '小明'     when 3 then '小陈'     else name end ;  update users set name = case id                when 1 then '小刚-1'                when 2 then '小明-1'                else name     end where id in (1,2,3) ;

相关内容

热门资讯

解迷了解!欢乐茶馆脚本(辅助)... 解迷了解!欢乐茶馆脚本(辅助)众悦棋牌果然是有辅助安装(哔哩哔哩)解迷了解!欢乐茶馆脚本(辅助)众悦...
专业了解!闲逸碰胡外桂(辅助)... 专业了解!闲逸碰胡外桂(辅助)兴动麻将确实真的是有辅助软件(哔哩哔哩)1、完成闲逸碰胡外桂辅助器v3...
关于了解!小程序游戏辅助器(辅... 关于了解!小程序游戏辅助器(辅助)旭盛原来真的是有辅助软件(哔哩哔哩)1、小程序游戏辅助器破解器简单...
透视了解!微乐贵阳足鸡麻将开挂... 透视了解!微乐贵阳足鸡麻将开挂(辅助)闲来安徽麻将确实真的是有辅助脚本(哔哩哔哩)1、微乐贵阳足鸡麻...
必备了解!开心十三张有没有挂(... 必备了解!开心十三张有没有挂(辅助)穿过夏天的风一直存在有辅助下载(哔哩哔哩)小薇(辅助器软件下载)...
解密了解!hhpoker挂免费... 解密了解!hhpoker挂免费辅助器(辅助)营口52麻将本来是有辅助平台(哔哩哔哩)1、进入到hhp...
总结了解!陕麻圈修改工具(辅助... 总结了解!陕麻圈修改工具(辅助)鼎吉其实是真的辅助app(哔哩哔哩)1、打开软件启动之后找到中间准星...
普及了解!越乡游义乌辅助器下载... 普及了解!越乡游义乌辅助器下载(辅助)天天遇难麻将好像是有辅助工具(哔哩哔哩)运越乡游义乌辅助器下载...
关于了解!微信小程序游戏破解微... 关于了解!微信小程序游戏破解微乐游戏(辅助)腾龙果然是真的辅助神器(哔哩哔哩)暗藏猫腻,小编详细说明...
解迷了解!天天爱消除辅助教程(... 解迷了解!天天爱消除辅助教程(辅助)微乐三打一果然是真的辅助挂(哔哩哔哩)1、每一步都需要思考,不同...