MySql中4种批量更新的方法

转载 2018年04月16日 18:29:06

最近在完成MySql项目集成的情况下,需要增加批量更新的功能,根据网上的资料整理了一下,很好用,都测试过,可以直接使用。

   mysql 批量更新共有以下四种办法

1、.replace into 批量更新

   replace into test_tbl (id,dr) values (1,'2'),(2,'3'),...(x,'y');
   例子:replace into book (`Id`,`Author`,`CreatedTime`,`UpdatedTime`) values (1,'张飞','2016-12-12 12:20','2016-12-12 12:20'),(2,'关羽','2016-12-12 12:20','2016-12-12 12:20');

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

  insert into test_tbl (id,dr) values (1,'2'),(2,'3'),...(x,'y') on duplicate key update dr=values(dr);

  例子:insert into book (`Id`,`Author`,`CreatedTime`,`UpdatedTime`) values (1,'张飞2','2017-12-12 12:20','2017-12-12 12:20'),(2,'关羽2','2017-12-12 12:20','2017-12-12 12:20') on duplicate key update Author=values(Author),CreatedTime=values(CreatedTime),UpdatedTime=values(UpdatedTime);

   replace into  和 insert into on duplicate key update的不同在于:

    replace into 操作本质是对重复的记录先delete 后insert,如果更新的字段不全会将缺失的字段置为缺省值,用这个要悠着点否则不小心清空大量数据可不是闹着玩的。
    insert into 则是只update重复记录,不会改变其它字段。

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

    create temporary table tmp(id int(4) primary key,dr varchar(50));
    insert into tmp values  (0,'gone'), (1,'xx'),...(m,'yy');
    update test_tbl, tmp set test_tbl.dr=tmp.dr where test_tbl.id=tmp.id;

   注意:这种方法需要用户有temporary 表的create 权限。

4、使用mysql 自带的语句构建批量更新

    mysql 实现批量 可以用点小技巧来实现:

    UPDATE yoiurtable
        SET dingdan = CASE id 
            WHEN 1 THEN 3 
            WHEN 2 THEN 4 
            WHEN 3 THEN 5 
        END
    WHERE id IN (1,2,3)

    这句sql 的意思是,更新dingdan 字段,如果id=1 则dingdan 的值为3,如果id=2 则dingdan 的值为4……
    where部分不影响代码的执行,但是会提高sql执行的效率。确保sql语句仅执行需要修改的行数,这里只有3条数据进行更新,而where子句确保只有3行数据执行。   

    例子:UPDATE book
        SET Author = CASE id 
            WHEN 1 THEN '黄飞鸿' 
            WHEN 2 THEN '方世玉'
            WHEN 3 THEN '洪熙官'
        END
    WHERE id IN (1,2,3)

    如果更新多个值的话,只需要稍加修改:

    UPDATE categories      
        SET dingdan = CASE id 
            WHEN 1 THEN 3 
            WHEN 2 THEN 4 
            WHEN 3 THEN 5 
        END, 
        title = CASE id 
            WHEN 1 THEN 'New Title 1'
            WHEN 2 THEN 'New Title 2'
            WHEN 3 THEN 'New Title 3'
        END
    WHERE id IN (1,2,3)

   例子:UPDATE book
        SET Author = CASE id 
            WHEN 1 THEN '黄飞鸿2' 
            WHEN 2 THEN '方世玉2'
            WHEN 3 THEN '洪熙官2'
        END,
        Code = CASE id 
            WHEN 1 THEN 'HFH2' 
            WHEN 2 THEN 'FSY2'
            WHEN 3 THEN 'HXG2'
        END
    WHERE id IN (1,2,3)

    到这里,已经完成一条mysql语句更新多条记录了。

    好了,很有用,记录下来,具体的Book的表结构不写了,大家可以建立自己的表结构,字段改成自己的字段就可以了。MySql是挺好用的。

天下国家,可均也;爵禄,可辞也;白刃,可蹈也;中庸不可能也

大批量更新数据mysql批量更新的四种方法

转载一篇大批量更新mysql数据的办法,为了便于阅读根据原文做了缩减。 mysql 批量更新如果一条条去更新效率是相当的慢, 循环一条一条的更新记录,一条记录update一次,这样性能很差,也很...
  • u014520745
  • u014520745
  • 2016-09-02 18:00:43
  • 65974

mysql进阶(十四) 批量更新与批量更新多条记录的不同值实现方法

mysql 批量更新与批量更新多条记录的不同值实现方法 在mysql中批量更新我们可能使用update,replace into来操作,下面详细介绍mysql批量更新与性能。 批量更新 ...
  • sunhuaqiang1
  • sunhuaqiang1
  • 2015-08-16 16:30:19
  • 50551

Mysql中批量更新的两种方式

批量插入并更新
  • luka2008
  • luka2008
  • 2014-09-23 10:10:19
  • 16772

mysql数据库批量更新操作

在mysql数据库中,如果要进行批量更新操作,必须在url上面加上allowMultiQueries=true...
  • wangxiaotongfan
  • wangxiaotongfan
  • 2016-06-07 23:02:18
  • 821

mybatis+mysql的批量更新

mybatis+mysql的批量更新
  • qq13398600329
  • qq13398600329
  • 2017-05-16 10:09:03
  • 3455

关于MySQL在项目中批量更新

在项目中遇到了批量更新数据的问题,翻阅了google并没有找到合适的文章,都是case    when  什么的,对于我这种新手来说并不能懂其原理。 统一批量更新单个字段或多个字段 实现原理: ...
  • wanghongbiao1993
  • wanghongbiao1993
  • 2017-03-21 10:30:49
  • 355

mybatis执行批量更新batch update 的方法(提供oracle,mysql两种写法)

oracle和mysql数据库的批量update在mybatis中配置不太一样:  oracle数据库:  update id="updatebatch"  param...
  • u014639561
  • u014639561
  • 2016-11-25 17:05:08
  • 2702

mysql设置批量更新

from: http://www.cnblogs.com/chenjianjx/archive/2012/08/14/2637914.html MySQL Jdbc驱动在默认情况下会无视exe...
  • hotdust
  • hotdust
  • 2016-06-04 17:14:35
  • 770

MySql中4种批量更新的方法(主要使用1,2)

如果是更新为同样的内容,没啥难度,直接在where里面下功夫就好了,大家都懂,我要说的是针对更新内容不一样的情况 首先,先看看网上转载的方法: mysql 批量更新如果一条条去更新效率是相...
  • h330531987
  • h330531987
  • 2018-01-20 15:31:37
  • 85

Mysql批量更新及插入(参数为Map)

前言         这个问题困扰了整整一天。         当遇到多条记录需要插入或者更新的时候,往往会使用批量操作来提高效率,提高性能。然而在使用过程中确是出现了各种问题,真的是有些坑只有趟过...
  • babylove_BaLe
  • babylove_BaLe
  • 2017-07-12 14:16:29
  • 1147
收藏助手
不良信息举报
您举报文章:MySql中4种批量更新的方法
举报原因:
原因补充:

(最多只允许输入30个字)