Mysql批量插入更新

Wesley13
• 阅读 620

批量插入,使用MyBatis批量语法:

<insert id="insertBatch" parameterType="list">
    insert into tbl1 (a, b, c)
    values
    <foreach collection="list" item="obj" separator=",">
        (#{obj.a,jdbcType=TIMESTAMP}, #{obj.b,jdbcType=VARCHAR}, #{obj.c,jdbcType=VARCHAR})
    </foreach>
</insert>

使用临时表进行批量更新,其中的a,b作为唯一索引:

insert into tbl1  (a, b , c,d,e)
SELECT a, b ,c,d,e from tbl1_temp s 
on DUPLICATE key update c = s.c, d = s.d, e=s.e

3万条记录,第一次插入的时候1.5秒,第二次更新的时候2.5秒;

而且不会影响到该条记录的其他字段;

REPLACE into tbl1  (a, b , c,d,e)
SELECT a, b ,c,d,e from tbl1_temp s

3万条记录,第一次插入的时候2.5秒,第二次更新的时候4.5秒;

REPLACE的时候会把记录删除重新插入,自增主键可以看出变化;

该条记录的其他字段会被清空,使用默认值填入;

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Wesley13 Wesley13
3年前
mybatis执行批量更新batch update 的方法(oracle,mysql)
介绍oracle和mysql数据库的批量update在mybatis中配置不太一样:oracle数据库:\codesyntaxlang"java"\updateid"batchUpdate"parameterType"java.util.List"<foreachcollection"list"item
Wesley13 Wesley13
3年前
mysql 批量更新
mysql批量更新共有以下四种办法1、replaceinto批量更新replaceinto表名l(id,字段1)values(1,'2'),(2,'3'),...(x,'y');2、insertinto...onduplicatekeyupdate批量更新insertint
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Stella981 Stella981
3年前
Android蓝牙连接汽车OBD设备
//设备连接public class BluetoothConnect implements Runnable {    private static final UUID CONNECT_UUID  UUID.fromString("0000110100001000800000805F9B34FB");
Stella981 Stella981
3年前
Mybatisd对MySQL批量插入、批量更新及批量删除语句
1、批量插入<insertid"insertBatch"parameterType"java.util.List"insertintot_student(name,age,class)values<forea
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
thinkphp 基本配置
12returnarray(34//定义数据库连接信息5'DB\_TYPE''mysql',//指定数据库是mysql67'DB\_HOST''localhost',89'DB\_NAME''uchome',//数据库名1011'DB\_USER''root
Wesley13 Wesley13
3年前
mysql 插入数据
简单用法:insertintotb\_name(字段1,字段2,.........)values(值1,值2,.....)注意,字段个数必须和值的个数一致。字符用引号引起来,数字不用,插入空值使用null批量插入:insertintotb\_name(字段1,字段2,.........)values(值1,值2,.....