文档章节

oracle里通过merge语句判断重复插入

hefeiuu
 hefeiuu
发布于 2017/05/04 20:27
字数 296
阅读 2
收藏 0
由于项目中需要用到批量插入,为了防止用户插入重复的数据,需要先判断插入的数据是不是已经存在,如果存在则忽略这次插入,否则插入这条数据,刚开始的时候是先用一条SQL语句判断,如果返回结果是真(记录已经存在),则忽略,否则插入这条数据,这样的话插入一条数据就要发起两个到数据库的连接,后来发现这样做效率实在太低了,Google了一下,发现oracle数据库支持merge语句,做了个测试,成功了,记录下来供本人及同行以后查阅之用。

  数据库:TEST

 
 CREATE TABLE TEST(

  ID NUMBER NOT NULL,

  NAME VARCHAR2(30) NOT NULL,

  SEX VARCHAR2(2) DEFAULT '男'

  )


  插入两条数据:

 
 INSERT INTO TEST VALUES(1,'SUNZHENXING','男')

  INSERT INTO TEST VALUES(2,'SUNHAILONG','女')


  MERGE语句:

  MERGE INTO TEST A USING TEST B

  ON (A.NAME=B.NAME)

  WHEN MATCHED THEN

  UPDATE SET A.SEX='女'WHERE A.NAME='SUNZHENXING'

  WHEN NOT MATCHED THEN

  INSERT VALUES (3,'SUNZHENXING','女')

  需要注意的是:MERGE语句中的UPDATE语句和INSERT语句和一般的SQL语句格式有点不同

本文转载自:http://ufopw.iteye.com/blog/962674

共有 人打赏支持
上一篇: XFire开发指南
下一篇: javadoc注释规范
hefeiuu
粉丝 3
博文 64
码字总数 0
作品 0
合肥
私信 提问
Merge into的使用详解

Merge是一个非常有用的功能,类似于Mysql里的insert into on duplicate key. Oracle在9i引入了merge命令, 通过这个merge你能够在一个SQL语句中对一个表同时执行inserts和updates操作. 当然是...

mrliuze
2015/07/20
0
0
Mysql 原生语句中save or update 的各种写法

Mysql 原生语句中save or update 的各种写法 背景   在平常的开发中,经常碰到这种更新数据的场景:先判断某一数据在库表中是否存在,存在则update,不存在则insert。如果使用Hibernate,它...

Tek_Eternal
2015/02/09
0
0
oracle中merge的用法,以及各版本的区别 Create

Merge是一个非常有用的功能,类似于Mysql里的insert into on duplicate key. Oracle在9i引入了merge命令, 通过这个merge你能够在一个SQL语句中对一个表同时执行inserts和updates操作. 当然是...

开源中国技术顾问
2016/01/22
57
0
Java 程序员在写 SQL 程序时候常犯的 10 个错误

Featured article by oschina reproduced with permission by Data Geekery GmbH. English content copyright © 2013 by Data Geekery GmbH. Java程序员编程时需要混合面向对象思维和一般命......

oschina
2013/08/03
14.3K
70
数据库根据键值自动判断插入还是更新的SQL

MySQL 至4.1版以后开始支持INSERT … ON DUPLICATE KEY UPDATE INSERT INTO 表名 (字段1,字段2,……) VALUES (值1,值2,……) ON DUPLICATE KEY UPDATE 字段n=值n; 要使用这条语句,前提...

沉默的子明
2016/06/24
73
0

没有更多内容

加载失败,请刷新页面

加载更多

学习心得《稻盛和夫经营学》的读后感2300字

学习心得《稻盛和夫经营学》的读后感2300字: 作者:张宪军;稻盛和夫信奉明朝王阳明的一句话:良知没处,万法难度。人们把它理解为管理者要有在纯正心态下要有好的做事方法,不然是很难成功...

原创小博客
17分钟前
0
0
红外接收器驱动开发

背景:使用系统的红外遥控软件没有反应,然后以为自己接线错误,反复测试,结果烧坏了一个红外接收器,信号主板没有问题。所以自己开发了一个红外接收器的python驱动。接线参见https://my.os...

mbzhong
39分钟前
2
0
ActiveMQ消息传送机制以及ACK机制详解

AcitveMQ是作为一种消息存储和分发组件,涉及到client与broker端数据交互的方方面面,它不仅要担保消息的存储安全性,还要提供额外的手段来确保消息的分发是可靠的。 一. ActiveMQ消息传送机...

watermelon11
今天
1
0
HashTable和Vector为什么逐渐被废弃

HashTable,不允许键值为null,还一个就是put方法使用sychronized方法进行线程同步,单线程无需同步,多线程可用concurren包的类型。 如编程思想里面说的作为工具类,封闭性做的不好没有一个...

noob_chr
昨天
1
0
Win10 下安装Win7双系统

很多人买了预装64位Win8/8.1的电脑后想重装(或者再安装一个)Win7系统,但是折腾半天发现以前的方法根本不奏效。这是因为预装Win8/8.1的电脑统一采用了UEFI+GPT引导模式,传统的BIOS(Legacy...

yaly
昨天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部