mysql之replace into与 insert into duplicat key for update
mysql实际应用中,我们在插入数据的时候,经常遇到主键冲突的情况,这是因为库中已经存在相同主键的数据,这时,我们只能更新数据;在判断是更新数据还是插入数据,我们还需要在此之前做一些必要的判断;在mysql中有没有一种集插入更新于一体的方法呢,答案是有,这就是insert into 的加强版replace into
tableName values()和insert into tableName values() on duplicat key update ...
1.创建测试表并插入数据
create table replaceTest(
id int not null auto_increment,
name varchar(20) ,
addr varchar(100),
primary key (id)
)charset = utf8
-- 插入数据
insert into replaceTest values(null,'aa','bbbbbb'),(null,'cc','ddddd'),(null,'ee','fffff');
2.replace into 是insert into 的加强版,既可以更新数据也可以插入数据;它的执行逻辑是:首先判断是否存在相同的唯一主键或者唯一索引,如果存在,在更新数据,否则,插入数据,例如:
之所以会是2行数据受到影响,是因为表中已存在主键为1的数据,mysql先将原有的数据删除,并将新的数据插入,因此受影响的是2行数据
在看下面的例子:
查询结果,说明是先删除后插入:
3.insert into on duplicat key udpate 和replace into 类似,也是可以插入和更新,它们的不同点是,insert into 只更新update后面的字段。
4.总结:如果存在相同的主键或唯一索引,replace into 相当于先删除数据而后在插入,如果不存在相同的主键和唯一索引,则直接插入。
如果存在相同的主键或唯一索引,insert into on duplicate key update只更新update后面的字段,相当于udpate ;如果不存在相同的主键或唯一索引,则直接插入
最新文章
- 利用NSCalendar类实现日期的比较
- $.extend()、$.fn和$.fn.extend()
- [WPF系列]-Data Validation
- [转载]我的Java后端书架 (2016年暖冬4.0版)
- ES6的Iterator,jquery Fn
- Moqui学习Day2
- Java String类详解
- 张艾迪(创始人):拥抱单身与自由的Eidyzhang
- 看文档要看仔细,英语要加强啊... cocos2d-x 的 API 和 对应版本的 cocos2d-js 的 API 没有完全对应
- 极客”一词,来自于美国俚语“geek”的音译,一般理解为性格古怪的人
- Core Data 和 sqlite3的性能对比【图】3gs,iPhone4,4s,5的性能测试。
- python入门(Python和Pycharm安装)
- OLAP + MDX
- Dev-FAT-UAT-PRO
- [转帖]将改名贯彻到底,Xeon E3系列将改名为Xeon E
- BZOJ3459 : Bomb
- Android sdk 更新后编译不过,【Could not find com.android.sdklib.build.ApkBuilderMain】
- B+树索引
- 第十章 Secret &; Configmap (中)
- 无线局域网中RADIUS协议原理与实现