SQL语句 存在就更新不存在就插入

在向表中插入数据的时候,经常遇到这样的情况:

  1. 首先判断数据是否存在;
  2. 如果不存在,则插入:
  3. 如果存在,则更新。

SQL server

脚本先查询,没有数据再进行数据插入,有数据就走更新

mysql

replace into 跟 insert 功能类似,不同点在于:replace into 首先尝试插入数据到表中。

  1. 如果发现表中已经有此行数据(根据主键或者唯一索引判断)则先删除此行数据,然后插入新的数据。
  2. 否则,直接插入新数据。
    Ps:要注意的是:插入数据的表必须有主键或者是唯一索引!否则的话,replace into 会直接插入数据,这将导致表中出现重复的数据。

oracle

脚本先查询,如果有数据表先进行删除操作,然后在进行新增表操作。
同样的,如果是数据,会先查询数据,如果有就进行删除,删除后再进行插入,如果没有就直接进行插入

 

1:隐式游标法 SQL%NOTFOUND SQL%FOUND
SQL%NOTFOUND 是SQL中的一个隐式游标,在增删查改的时候自动打开,如果有至少有一条记录受影响,都会返回false,这就就巧妙的构思出了第一种解决方案:

2:异常法 DUP_VAL_ON_INDEX
当Oracle语句执行时,发生了异常exception进行处理,需要唯一索引id,重复插入出现异常

3:虚拟表法 dual:
dual是一个虚拟表,用来构成select的语法规则,oracle保证dual里面永远只有一条记录。

4:no_data_found法
先查找要插入的记录是否存在,存在则修改,不存在则插入。具体的实现如下:

5:merge法
先来看一下merge的语法

 

浏览量: 54