mysql:on duplicate key update与replace into

在往表里面插入数据的时候,经常需要:a.先判断数据是否存在于库里面;b.不存在则插入;c.存在则更新

一、replace into

  前提:数据库里面必须有主键或唯一索引,不然replace into 会直接插入新数据,导致数据表里面有重复数据

  执行时先尝试插入数据:

    a.当数据表里面存在(通过主键或唯一索引来判断)该数据,则先将表里的数据删除,再插入新的数据

    b.如果数据表里面不存在该数据,则直接插入数据

  replace into是insert into的增强版,语法跟insert iton差不多

    replace into table_name(columns)values(values1,values2);

    replace into table_name(columns) select columns from table_name2

  测试数据(该表建立了一个复合的唯一索引user_add):

    CREATE TABLE `relace_on` (

      `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
      `user_id` int(11) unsigned NOT NULL,
      `interal` tinyint(3) unsigned NOT NULL,
      `add_time` date NOT NULL,
      PRIMARY KEY (`id`),
      UNIQUE KEY `user_add` (`user_id`,`add_time`) USING BTREE
    ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=latin1;

  插入测试数据:    

    INSERT INTO relace_on (user_id, interal, add_time)
    VALUES
    (1,20,‘2016-05-06‘),
    (2,20,‘2016-05-06‘),
    (3,20,‘2016-05-06‘),
    (1,20,‘2016-05-07‘),
    (2,20,‘2016-05-07‘),
    (3,20,‘2016-05-07‘)

  现在数据库数据:

    

  接下来执行一下replace into语句(存在):replace INTO relace_on(user_id, interal, add_time)values(1,40,‘2016-05-06‘),(2,60,‘2016-05-06‘),(3,80,‘2016-05-06‘)

  此时sql执行成功,受影响行数为6行(删除三条,插入三条)

  对比一下你会发现user_id(1,2,3)的账户在2016-05-06这一天原先都是有数据的,并且id为(1,2,3);现在执行了replace into后,id变成了(7,8,9),并且interal字段的值为执行语句的值,此时replace into语句根据数据表中的user_add这个复合的唯一索引发现在数据表中user_id为(1,2,3)的用户在2016-05-06这天各存在一条记录,这时就把原先的三条数据删除了,重新插入了三条,所以id从1,2,3变成了7,8,9;并且interal的值也变了

  接下来执行一下replace into语句(不存在):replace INTO relace_on(user_id, interal, add_time)values(4,40,‘2016-05-06‘),(5,60,‘2016-05-06‘),(6,80,‘2016-05-06‘)

  此时sql执行成功,受影响行数为3行(插入三条)

  对比上图,你会发现原先的数据没变,只是新增了三条数据,同样是2016-05-06这天的,但是user_id是(4,5,6)根据user_add这个复合的唯一索引,这三条数据不存在数据表中,所以直接插入即可

    

二、on duplicate key update

  它也是可以用于更新数据的,跟replace into有点相似,但是on duplicate key update是数据表里面存在该数据就更新,不存在则插入,;而replace into则是存在就删除,再插入,不存在则插入

  依旧使用上面现有的数据来测试:

  先添加一个字段,用于等下更新多个字段之用:ALTER TABLE `relace_on` ADD COLUMN `copy_interal` tinyint(3) UNSIGNED NOT NULL AFTER `interal`;

  语法:

    更新单个字段:insert into table_name(columns)values(values1,values2) on duplicate key update column=values(column)或者column=value(1,‘zgw‘)

    更新多个字段:insert into table_name(columns)values(values1,values2) on duplicate key update column1=values(column1),column2=values(column2)

  执行一条语句(存在):insert into relace_on(user_id, interal,copy_interal, add_time)values(6,100,200,‘2016-05-06‘) on duplicate KEY update interal=values(interal),copy_interal=values(copy_interal)

  

  如图,user_id=6,add_time=‘2016-05-06‘这条数据存在,则更新interal和copy_interal两个字段的值(interal原先为80,copy_interal新增字段默认为0)

  再次执行一条语句(不存在):insert into relace_on(user_id, interal,copy_interal, add_time)values(7,100,200,‘2016-05-06‘) on duplicate KEY update interal=values(interal),copy_interal=values(copy_interal)

  

时间: 2024-11-03 05:31:40

mysql:on duplicate key update与replace into的相关文章

mysql ON DUPLICATE KEY UPDATE、REPLACE INTO

INSERT INTO ON DUPLICATE KEY UPDATE 与 REPLACE INTO,两个命令可以处理重复键值问题,在实际上它之间有什么区别呢?前提条件是这个表必须有一个唯一索引或主键. 1.REPLACE发现重复的先删除再插入,如果记录有多个字段,在插入的时候如果有的字段没有赋值,那么新插入的记录这些字段为空.2.INSERT发现重复的是更新操作.在原有记录基础上,更新指定字段内容,其它字段内容保留. 这样REPLACE的操作成本要大于 insert  ON DUPLICATE

MySQL: ON DUPLICATE KEY UPDATE 用法

使用该语法可在插入记录的时候先判断记录是否存在,如果不存在则插入,否则更新,很方便,无需执行两条SQL 这个语句知识mysql中,而标准sql语句中是没有的. INSERT INTO .. ON DUPLICATE KEY更新多行记录 如果在INSERT语句末尾指定了ON DUPLICATE KEY UPDATE,并且插入行后会导致在一个UNIQUE索引或PRIMARY KEY中出现重复值,则执行旧行UPDATE:如果不会导致唯一值列重复的问题,则插入新行.例如,如果列a被定义为UNIQUE,并

深入mysql "ON DUPLICATE KEY UPDATE" 语法的分析

mysql "ON DUPLICATE KEY UPDATE" 语法如果在INSERT语句末尾指定了ON DUPLICATE KEY UPDATE,并且插入行后会导致在一个UNIQUE索引或PRIMARY KEY中出现重复值,则在出现重复值的行执行UPDATE:如果不会导致唯一值列重复的问题,则插入新行. 例如,如果列 a 为 主键 或 拥有UNIQUE索引,并且包含值1,则以下两个语句具有相同的效果: 复制代码代码如下: INSERT INTO TABLE (a,c) VALUES

mysql ON DUPLICATE KEY UPDATE ;

需求: 1)如果admin表中没有数据, 插入一条 2)如果admin表中有数据, 不插入. 一般做法: 1 if($result = mysql_query("select * from admin")) 2 { 3 if(mysql_num_rows($result)) 4 { 5 echo "<br/>admin表中已经有数据了"; 6 } 7 else 8 { 9 $sql = " insert into admin (`adminNa

mysql ON DUPLICATE KEY UPDATE重复插入时更新

mysql当插入重复时更新的方法: 第一种方法: 示例一:插入多条记录 假设有一个主键为 client_id 的 clients 表,可以使用下面的语句: INSERT INTO clients (client_id,client_name,client_type) SELECT supplier_id,supplier_name,'advertising' FROM suppliers WHERE not exists(select * from clients where clients.c

insert into ... on duplicate key update 与 replace 区别

on duplicate key update:针对主健与唯一健,当插入值中的主健值与表中的主健值,若相同的主健值,就更新on duplicate key update 后面的指定的字段值,若没有相同主健值,就插入该记录 mysql> create table tab_test(fd1 int NOT NULL,fd2 varchar(50),primary key(fd1))engine=innodb; Query OK, 0 rows affected (0.22 sec) mysql>

MySQL ON DUPLICATE KEY UPDATE 语法

一.前言 在日常业务开发中经常有这样一个场景,首先创建一条记录,然后插入到数据库,如果数据库已经存在同一主键的记录,执行update操作:否则,执行insert操作.这个操作可以在业务层做,也可以在数据库层面做.业务层一般做法是先查询,如果不存在就插入,如果存在就更新:但是查询和插入不是原子性操作,在并发量比较高的时候,可能两个线程都查询不到某个记录,所以会执行两次插入,其中一条必然会因为唯一性约束冲突而失败.数据库层mysql中INSERT ... ON DUPLICATE KEY UPDAT

MySQL "ON DUPLICATE KEY UPDATE" 使用

一.insert or update需求 需求:如果test_table中存在记录则update,不存在则insert. 二.老做法:3条sql select * from test_table where id = 1;   //查询表中是否已有记录 insert into test_table (id,name) values(1,'may');   //记录不存在,执行insert update test_table set name = 'may' where id = 1;  //记录

my -&gt; mysql on duplicate key update使用总结

CREATE TABLE `t_duplicate` ( `a` int(11) NOT NULL, `b` int(255) DEFAULT NULL, `c` int(255) DEFAULT NULL, PRIMARY KEY (`a`) USING BTREE) ENGINE=InnoDB DEFAULT CHARSET=latin1 COMMENT='测试验证on duplicate key update 功能'; SELECT * FROM `t_duplicate`; #添加和更新