大批量数据用mysql批量更新数据的4种方法总结

 更新时间:2024年05月06日 11:08:12   作者:小哇666  
这篇文章主要给大家介绍了关于大批量数据用mysql批量更新数据的4种方法,要在MySQL中新增大批量数据,可以通过以下几种方法来实现,文中给出了详细的代码示例,需要的朋友可以参考下

建一个测试表

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) ;

总结

到此这篇关于大批量数据用mysql批量更新数据的4种方法总结的文章就介绍到这了,更多相关mysql批量更新数据方法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL如何更改数据库数据存储目录详解

    MySQL如何更改数据库数据存储目录详解

    这篇文章主要给大家介绍了关于MySQL如何更改数据库数据存储目录的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-11-11
  • MySQL与PHP的基础与应用专题之数据完整性

    MySQL与PHP的基础与应用专题之数据完整性

    MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,本系列将带你掌握php与mysql的基础应用,本篇从数据完整性开始
    2022-02-02
  • MySQL中的排序规则

    MySQL中的排序规则

    这篇文章主要介绍了MySQL中的排序规则,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • MySQL单表记录数过大的优化方法

    MySQL单表记录数过大的优化方法

    当MySQL单表记录数过大时,采取合理的优化策略是保障系统高性能的关键,本博客详细介绍了索引优化、分区表、垂直拆分、水平拆分等多种优化手段,并提供了详细的代码示例,感兴趣的朋友一起看看吧
    2024-01-01
  • MySQL 数据库 like 语句通配符模糊查询小结

    MySQL 数据库 like 语句通配符模糊查询小结

    这篇文章主要介绍了MySQL 数据库 like 语句通配符模糊查询小结,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-10-10
  • mysql 5.7.17 安装配置方法图文教程(ubuntu 16.04)

    mysql 5.7.17 安装配置方法图文教程(ubuntu 16.04)

    这篇文章主要为大家分享了ubuntu 16.04下mysql 5.7.17 安装配置方法图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • MySQL表的CURD操作(数据的增删改查)

    MySQL表的CURD操作(数据的增删改查)

    数据库本质上是一个文件系统,通过标准的SQL语句对数据进行CURD操作,下面这篇文章主要给大家介绍了关于MySQL表的CURD操作的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-02-02
  • navicat 连接Ubuntu虚拟机的mysql的操作方法

    navicat 连接Ubuntu虚拟机的mysql的操作方法

    这篇文章主要介绍了navicat 连接Ubuntu虚拟机的mysql的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-04-04
  • mysql 的load data infile

    mysql 的load data infile

    前些日子在开发一个舆情监测系统,需要在一个操作过程中往数据表里插入大量的数据,为了改变以往生硬地逐条数据插入的笨办法,也为了提高执行效率,决定用load data infile来执行数据插入。
    2009-05-05
  • MySQL触发器之判断更新操作前后数据是否改变

    MySQL触发器之判断更新操作前后数据是否改变

    这篇文章主要介绍了MySQL触发器之判断更新操作前后数据是否改变方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08

最新评论