zoukankan      html  css  js  c++  java
  • [原] insert into … on duplicate key update / replace into 多行数据

    场景是这样的,我有KV型的表,建表语句如下:

    CREATE TABLE `dkv` (
      `k1` int(11) NOT NULL DEFAULT '0',
      `k2` int(11) NOT NULL DEFAULT '0',
      `val` varchar(30) DEFAULT NULL,
      PRIMARY KEY (`k1`,`k2`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8

    数据大概是这样的:

    +----+----+-----------+
    | k1 | k2 | val       |
    +----+----+-----------+
    |  1 |  1 | value 1-1 |
    |  1 |  2 | value 1-1 |
    |  1 |  3 | value 1-1 |
    |  1 |  5 | value 1-1 |
    |  1 |  7 | value 1-1 |
    +----+----+-----------+

    当我插入一条数据时,我要判断(k1,k2)是否已经存在(1条selete),若存在就update,不存在就insert,这是一个典型的merge过程,虽然按照PK执行操作的速度非常快,但是毕竟SQL交互量上去了,如果我有100笔这样的SQL,那这个开销是很可观的,有没有什么一条SQL就能搞定的事情呢?

    有两种写法:

    第一种: insert into … on duplicate key update

    insert DELAYED into dkv 
    values 
    (1,2,'new 12a'),
    (1,3,'new 33ba'),
    (1,4,'new 23222'),
    (1,6,'new 12333'),
    (1,8,'new vaaaa'),
    (1,20,'new vaff'),
    (1,25,'new vaff')
    ON DUPLICATE KEY UPDATE val=VALUES(val);

    第二种 replace into:

    replace into dkv 
    values 
    (1,2,'new 12a'),
    (1,3,'new 33ba'),
    (1,4,'new 23222'),
    (1,6,'new 12333'),
    (1,8,'new vaaaa'),
    (1,20,'new vaff'),
    (1,25,'new vaff');

    最终都能将数据改成这样:

    +----+----+-----------+
    | k1 | k2 | val       |
    +----+----+-----------+
    |  1 |  1 | value 1-1 |
    |  1 |  2 | new 12a   |
    |  1 |  3 | new 33ba  |
    |  1 |  4 | new 23222 |
    |  1 |  5 | value 1-1 |
    |  1 |  6 | new 12333 |
    |  1 |  7 | value 1-1 |
    |  1 |  8 | new vaaaa |
    |  1 | 20 | new vaff  |
    |  1 | 25 | new vaff  |
    +----+----+-----------+
  • 相关阅读:
    ThingsBoard 二次开发之源码分析 3-启动分析 2
    ThingsBoard 二次开发之源码分析 2-启动分析 1
    ThingsBoard 二次开发之源码分析 1- 基础知识
    ThingsBoard 2.5.3发布
    ThingsBoard 3.1 发布
    物联网 IoT 使用 Node-RED 的 5 大理由
    Thingsboard 简单教程:使用 ThingsBoard 查看物联网数据
    如何下载并安装应用商城应用
    如何优雅的在Markdown中使用图片
    Windows键盘无法调起
  • 原文地址:https://www.cnblogs.com/killkill/p/2736479.html
Copyright © 2011-2022 走看看