`
jackytang520
  • 浏览: 136049 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Merge 语句的使用

阅读更多
DB2 Merge 语句的作用非常强大,它可以将一个表中的数据合并到另一个表中,在合并的同时可以进行插入、删除、更新等操作。我们还是先来看个简单的例子吧,假设你定义了一个雇员表(employe),一个经理表(manager),如下所示:



---雇员表(EMPLOYE) 
CREATE TABLE EMPLOYE ( 
EMPLOYEID INTEGER  NOT NULL,---员工号 
NAME VARCHAR(20) NOT NULL,---姓名 
SALARY DOUBLE---薪水 
); 
INSERT INTO EMPLOYE (EMPLOYEID,NAME,SALARY) VALUES  
(1,'张三',1000), 
(2,'李四',2000), 
(3,'王五',3000), 
(4,'赵六',4000), 
(5,'高七',5000); 
--经理表(MANAGER) 
CREATE TABLE MANAGER ( 
EMPLOYEID INTEGER  NOT NULL,---经理号 
NAME VARCHAR(20) NOT NULL,---姓名 
SALARY DOUBLE---薪水 
); 
INSERT INTO MANAGER (MANAGERID,NAME,SALARY) VALUES  
(3,'王五',5000), 
(4,'赵六',6000); 


经过一段时间,你发现这样的数据模型,或者说表结构设计简直就是一大败笔,经理和雇员都是员工嘛,为什么要设计两个表呢?发现错误后就需要改正,所以你决定,删除经理表(MANAGER)表,将MANAGER 表中的数据合并到EMPLOYE 表中,仔细分析发现,王五在两个表中都存在(可能是干的好升官了),而刘八在EMPLOYE 表中并不存在,现在,我们要求把EMPLOYE 表中不存在的MANAGER都插入到EMPLOYE 表中,存在的更新薪水。该怎么办呢?这个问题并不难,通常,我们可以分两步,如下所示:

--更新存在的 
UPDATE EMPLOYE AS EM SET SALARY=(SELECT SALARY FROM MANAGER WHERE MANAGERID=EM.EMPLOYEID) 
WHERE EMPLOYEID IN ( 
SELECT MANAGERID FROM MANAGER 
); 
---插入不存在的 
INSERT INTO EMPLOYE (EMPLOYEID,NAME,SALARY) 
SELECT MANAGERID,NAME,SALARY FROM MANAGER WHERE MANAGERID NOT IN ( 
SELECT EMPLOYEID FROM EMPLOYE 
); 


上面的处理是可以的,但是我们还可以有更简单的方法,就是用Merge语句,如下所示:

MERGE INTO EMPLOYE AS EM 
USING MANAGER AS MA 
ON EM.EMPLOYEID=MA.MANAGERID 
WHEN MATCHED THEN UPDATE SET EM.SALARY=MA.SALARY 
WHEN NOT MATCHED THEN INSERT VALUES (MA.MANAGERID,MA.NAME,MA.SALARY); 


在上面的处理中,我们用经理表(MANAGER)的薪水更新了雇员表(EMPLOYE)的薪水,假设现在要求,如果经理表(MANAGER)的薪水>雇员表(EMPLOYE)的薪水的时候更新,否则不更新,怎么办呢?如下:

MERGE INTO EMPLOYE AS EM 
USING MANAGER AS MA 
ON EM.EMPLOYEID=MA.MANAGERID 
WHEN MATCHED AND EM.SALARY<MA.SALARY THEN UPDATE SET EM.SALARY=MA.SALARY 
WHEN NOT MATCHED THEN INSERT VALUES (MA.MANAGERID,MA.NAME,MA.SALARY); 


不仔细的朋友可能没有看出上面两条语句的区别,哈哈,请仔细对比一下这两条语句。上面的语句中多了ELSE IGNORE语句,它的意思正如它英文的意思,其它情况忽略不处理。如果你认为理论上应该不存在EM.SALARY>MA.SALARY的数据,如果有,说明有问题,你想抛个异常,怎么办?如下:

MERGE INTO EMPLOYE AS EM 
USING MANAGER AS MA 
ON EM.EMPLOYEID=MA.MANAGERID 
WHEN MATCHED AND EM.SALARY<MA.SALARY THEN UPDATE SET EM.SALARY=MA.SALARY 
WHEN MATCHED AND EM.SALARY>MA.SALARY THEN SIGNAL SQLSTATE '70001' SET MESSAGE_TEXT = 'EM.SALARY>MA.SALARY' 
WHEN NOT MATCHED THEN INSERT VALUES (MA.MANAGERID,MA.NAME,MA.SALARY) 
ELSE IGNORE; 


对于EM.SALARY>MA.SALARY的情况,如果你不想抛异常,而是删除EMPLOYE中的数据,怎么办?如下:

MERGE INTO EMPLOYE AS EM 
USING MANAGER AS MA 
ON EM.EMPLOYEID=MA.MANAGERID 
WHEN MATCHED AND EM.SALARY<MA.SALARY THEN UPDATE SET EM.SALARY=MA.SALARY 
WHEN MATCHED AND EM.SALARY>MA.SALARY THEN DELETE 
WHEN NOT MATCHED THEN INSERT VALUES (MA.MANAGERID,MA.NAME,MA.SALARY) 
ELSE IGNORE; 


以上简单介绍了Merge语句的使用,它的应用不只是上面介绍的情况,其实它可以应用在很多其他语句不好处理情况,这需要你去发现,记住熟能生巧。

转自:http://blog.csdn.net/shangboerds/article/details/4775422
分享到:
评论

相关推荐

    DB2 merge语句使用教程

    DB2 merge语句使用教程

    解析SQL Server 2008中的新语句:MERGE

    根据一个源数据表对另一个数据表进行确定性的插入、更新和删除这样复杂的操作,运用新的MERGE语句,开发者用一条命令就可以完成。对两个表进行信息同步时,有三步操作要进行。首先要处理任何需要插入目标数据表的新...

    使用BULK COLLECT, MERGE 语句提高sql执行效率

    详细介绍了使用 BULK COLLECT 进行批量操作 提高sql的执行效率 使用MERGE INTO USING 一条sql搞定 新增和修改 使用connect by 进行递归树查询

    DB2 MERGE INTO语句的使用

    DB2中的Merge语句可以将一个表中的数据合并到另一个表中,在合并的同时可以根据条件进行插入、删除、更新等操作,功能非常强大。

    触发器Merge语句执行.txt

    可通过merge语句功能,进行数据同步存储功能,里面有具体事例可供参考。大大减少了开发时间,提高了工作执行效率。

    Merge Into 语句代替InsertUpdate

    非常经典的SQL经验,适合于数据库初学者及长期从事软件开发者

    MySQL中实现插入或更新操作(类似Oracle的merge语句)

    主要介绍了在MySQL中实现插入或更新操作(类似Oracle的merge语句)的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下

    generate-sql-merge:生成带有表数据SQL MERGE语句

    生成带有表数据SQL MERGE语句 该系统存储过程将表名作为参数,并生成包含所有表数据的MERGE语句。 如果您需要,例如,这很有用。 生成的MERGE语句可以包含在源代码管理中,并用于在DEV / TEST / PROD之间部署数据。...

    SQL Server使用Merge语句当源表数据集为空时,无法进行查询的问题

    今天使用Merge语句时遇到了一个问题,当源表数据集为空时,merge就不工作了。

    Hibernate中的merge使用详情解说.docx

    当ID在数据库中能找到的时候,update与merge的执行效果都是更新数据,发出update语句; 如果没有设置ID的话,则这个对象就当作瞬态处理: 用update的话,由于没有ID,所以会报异常,merge此时则会保存数据,根据ID...

    Merge-Sql.zip

    本文探讨如何在不同的数据库中使用这些MERGE语句。我们将检查其他替代方法,因为所有数据库和版本都不支持MERGE语句。

    Oracle_merge

    在Oracle 9i R2版中引入的MERGE语句通常被称作“更新插入”(upsert),因为使用MERGE可以在同一个步骤中更新(update)并插入(insert)数据行。。。。。。

    merge用法详解

    无论你在使用任何DBMS,你总是难以避免的将会遇到上面提到的这种需求,如果你不使用merge语句,你将会不得不在程序中增加大段的代码,或者是在oracle用很长的代码来实现。好在现在我们有了merge,可以帮我们省下很多...

    SQLServer 2008 Merge语句的OUTPUT功能

    下面介绍一下把Output同2008的新T-SQL语句Merge组合使用的方法: 新建下面表: 代码如下:CREATE TABLE Book( ISBN varchar(20) PRIMARY KEY, Price decimal, Shelf int) CREATE TABLE WeeklyChange( ISBN varchar(20...

    SQL中Merge用法详解

    MERGE语句是SQL语句的一种。在SQL Server、Oracle数据库中可用,MySQL、PostgreSQL中不可用。MERGE是Oracle9i新增的语法,用来合并UPDATE和INSERT语句。通过MERGE语句,根据一张表(原数据表,source table)或子...

    Oracle merge合并更新函数实例详解

    MERGE语句是Oracle9i新增的语法,用来合并UPDATE和INSERT语句。 通过MERGE语句,根据一张表或多表联合查询的连接条件对另外一张表进行查询,连接条件匹配上的进行UPDATE,无法匹配的执行INSERT。这个语法仅需要一次...

    SQL Server 索引结构及其使用(二) 改善SQL语句第1/3页

    很多人不知道SQL语句在SQL SERVER中是如何执行的,他们担心自己所写的SQL语句会被SQL SERVER误解。

Global site tag (gtag.js) - Google Analytics