热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

OracleMERGEINTO的用法示例介绍

这篇文章主要介绍了OracleMERGEINTO的用法,需要的朋友可以参考下很多时候我们会出现如下情境,如果一条数据在表中已经存在,对其做update,如果不存在,将新的数据插入.如果不使用Oracle提供的merge语法的话,可能先要上数据库select查询一下看是否存在,然后决

这篇文章主要介绍了Oracle MERGE INTO的用法,需要的朋友可以参考下 很多时候我们会出现如下情境,如果一条数据在表中已经存在,对其做update,如果不存在,将新的数据插入.如果不使用Oracle提供的merge语法的话,可能先要上数据库select查询一下看是否存在,然后决

这篇文章主要介绍了Oracle MERGE INTO的用法,需要的朋友可以参考下

很多时候我们会出现如下情境,如果一条数据在表中已经存在,对其做update,如果不存在,将新的数据插入.如果不使用Oracle提供的merge语法的话,可能先要上数据库select查询一下看是否存在,然后决定怎么操作,这样的话需要写更多的代码,同时性能也不好,要来回数据库两次.使用merge的话则可以一条SQL语句完成.

1)主要功能

提供有条件地更新和插入数据到数据库表中

如果该行存在,,执行一个UPDATE操作,如果是一个新行,执行INSERT操作

— 避免了分开更新

— 提高性能并易于使用

— 在数据仓库应用中十分有用

2)MERGE语句的语法如下:

代码如下:

MERGE [hint] INTO [schema .] table [t_alias] USING [schema .]

{ table | view | subquery } [t_alias] ON ( condition )

WHEN MATCHED THEN merge_update_clause

WHEN NOT MATCHED THEN merge_insert_clause;

3)示例

代码如下:

MERGE INTO TABLE TARGET

USING (SELECT '111111111' STORE_NO,

'2014-01' TARGET_YM,

'1' TARGET_D01,

'2' TARGET_D02,

'2' TARGET_D03,

'2' TARGET_D04,

'2' TARGET_D05,

'2' TARGET_D06,

'2' TARGET_D07,

'2' TARGET_D08,

'2' TARGET_D09,

'2' TARGET_D10,

'2' TARGET_D11,

'2' TARGET_D12,

'2' TARGET_D13,

'2' TARGET_D14,

'2' TARGET_D15,

'2' TARGET_D16,

'2' TARGET_D17,

'2' TARGET_D18,

'2' TARGET_D19,

'2' TARGET_D20,

'2' TARGET_D21,

'2' TARGET_D22,

'2' TARGET_D23,

'2' TARGET_D24,

'2' TARGET_D25,

'2' TARGET_D26,

'2' TARGET_D27,

'2' TARGET_D28,

'2' TARGET_D29,

'2' TARGET_D30,

'2' TARGET_D31,

1 USER_ID

FROM DUAL) TEMP

ON (TARGET.STORE_NO = TEMP.STORE_NO AND TARGET.TARGET_YM = TEMP.TARGET_YM)

WHEN MATCHED THEN

UPDATE

SET TARGET.TARGET_D01 = TEMP.TARGET_D01,

TARGET.TARGET_D02 = TEMP.TARGET_D02,

TARGET.TARGET_D03 = TEMP.TARGET_D03,

TARGET.TARGET_D04 = TEMP.TARGET_D04,

TARGET.TARGET_D05 = TEMP.TARGET_D05,

TARGET.TARGET_D06 = TEMP.TARGET_D06,

TARGET.TARGET_D07 = TEMP.TARGET_D07,

TARGET.TARGET_D08 = TEMP.TARGET_D08,

TARGET.TARGET_D09 = TEMP.TARGET_D09,

TARGET.TARGET_D10 = TEMP.TARGET_D10,

TARGET.TARGET_D11 = TEMP.TARGET_D11,

TARGET.TARGET_D12 = TEMP.TARGET_D12,

TARGET.TARGET_D13 = TEMP.TARGET_D13,

TARGET.TARGET_D14 = TEMP.TARGET_D14,

TARGET.TARGET_D15 = TEMP.TARGET_D15,

TARGET.TARGET_D16 = TEMP.TARGET_D16,

TARGET.TARGET_D17 = TEMP.TARGET_D17,

TARGET.TARGET_D18 = TEMP.TARGET_D18,

TARGET.TARGET_D19 = TEMP.TARGET_D19,

TARGET.TARGET_D20 = TEMP.TARGET_D20,

TARGET.TARGET_D21 = TEMP.TARGET_D21,

TARGET.TARGET_D22 = TEMP.TARGET_D22,

TARGET.TARGET_D23 = TEMP.TARGET_D23,

TARGET.TARGET_D24 = TEMP.TARGET_D24,

TARGET.TARGET_D25 = TEMP.TARGET_D25,

TARGET.TARGET_D26 = TEMP.TARGET_D26,

TARGET.TARGET_D27 = TEMP.TARGET_D27,

TARGET.TARGET_D28 = TEMP.TARGET_D28,

TARGET.TARGET_D29 = TEMP.TARGET_D29,

TARGET.TARGET_D30 = TEMP.TARGET_D30,

TARGET.TARGET_D31 = TEMP.TARGET_D31,

TARGET.OPT_COUNTER = TARGET.OPT_COUNTER + 1,

TARGET.UPDATE_BY = TEMP.USER_ID,

TARGET.UPDATE_DATE = SYSDATE

WHEN NOT MATCHED THEN

INSERT

VALUES

(SEQ.NEXTVAL,

TEMP.STORE_NO,

TEMP.TARGET_YM,

TEMP.TARGET_D01,

TEMP.TARGET_D02,

TEMP.TARGET_D03,

TEMP.TARGET_D04,

TEMP.TARGET_D05,

TEMP.TARGET_D06,

TEMP.TARGET_D07,

TEMP.TARGET_D08,

TEMP.TARGET_D09,

TEMP.TARGET_D10,

TEMP.TARGET_D11,

TEMP.TARGET_D12,

TEMP.TARGET_D13,

TEMP.TARGET_D14,

TEMP.TARGET_D15,

TEMP.TARGET_D16,

TEMP.TARGET_D17,

TEMP.TARGET_D18,

TEMP.TARGET_D19,

TEMP.TARGET_D20,

TEMP.TARGET_D21,

TEMP.TARGET_D22,

TEMP.TARGET_D23,

TEMP.TARGET_D24,

TEMP.TARGET_D25,

TEMP.TARGET_D26,

TEMP.TARGET_D27,

TEMP.TARGET_D28,

TEMP.TARGET_D29,

TEMP.TARGET_D30,

TEMP.TARGET_D31,

NULL,

DEFAULT,

DEFAULT,

NULL,

TEMP.USER_ID,

DEFAULT,

NULL,

NULL);

小帮助:

看到数据库表这么多字段是不是好烦,拷贝、写都麻烦还容易出错,可以如下操作:

1、先查询出表的所有字段

代码如下:

SELECT COLUMN_ID,

COLUMN_NAME,

DATA_TYPE,

DATA_LENGTH,

DATA_PRECISION,

DATA_SCALE,

NULLABLE,

DATA_DEFAULT

FROM USER_TAB_COLUMNS

WHERE TABLE_NAME = 'TABLE'

ORDER BY COLUMN_ID

2、将该表列名拷贝到Excel,使用函数CONCATENATE

举一反三啦,很多时候都可以用到的,整理自网络

:更多精彩文章请关注三联编程教程栏目。

推荐阅读
  • databasesync适配openGauss使用指导书
    一、database-sync简介database-sync作为一种开源辅助工具,用于数据库之间的表同步,更确切的说法是复制,可以从一个数据库复制表到另一个数据库该工具支持的功能如 ... [详细]
  • 本文详细探讨了 Java 中 Daemon 线程的特点及其应用场景,并深入分析了 Random 类的源代码,帮助开发者更好地理解和使用这些核心组件。 ... [详细]
  • 深入理解Hibernate延迟加载机制
    本文探讨了Hibernate框架中的延迟加载(懒加载)特性,分析其对程序性能的影响及实现原理,同时提供了具体的代码示例来说明如何配置和使用延迟加载。 ... [详细]
  • 1、服务器配置信息① 主服务器IP:192.168.1.2② 从服务器IP:192.168.1.3③ 操作系统:主服务器:Win8,从服务器࿱ ... [详细]
  • 睿智汇海教育致力于培养杰出的IT专业人才,确保学员在就业市场上具备竞争力,助其实现职业成功。我们提供的C#/.Net/Asp.Net培训课程,旨在通过系统的教学和丰富的实践机会,帮助学员掌握最新的技术知识。 ... [详细]
  • 统一幻灯片标题:使用母版功能的技巧
    本文详细介绍了如何通过PowerPoint中的幻灯片母版功能,实现所有幻灯片标题的一致性设置。同时,提供了其他办公软件和编程相关的实用技巧。 ... [详细]
  • MySQL 5.7 绿色版安装及 my.ini 配置详解
    本文主要针对最近因系统重装导致的MySQL配置问题,详细介绍了MySQL 5.7.24绿色解压版的安装步骤及my.ini配置文件的关键设置,帮助用户顺利完成数据库的安装与配置。 ... [详细]
  • 本文介绍如何利用JavaScript在页面加载时为ASP.NET的DropDownList控件设置特定的选项值。 ... [详细]
  • MyBatis入门指南
    本文详细介绍了MyBatis的基础知识,包括如何整合日志框架(如log4j和logback),使用外部JDBC文件,getMapper()方法的应用,以及别名设置等技巧。 ... [详细]
  • 在使用 SQL 语句从数据库中提取数据并尝试将其转换为其他数据类型时,可能会遇到 'java.math.BigDecimal cannot be cast to java.lang.Integer' 错误。本文将详细解释这一错误的原因,并提供有效的解决方案。 ... [详细]
  • 本文探讨了如何利用脚本文件高效管理Oracle数据库,包括脚本文件的创建、编辑及运行方法,旨在为数据库管理人员提供实用指导。 ... [详细]
  • 使用H5在前端生成Excel文件的方法
    本文介绍了一种利用HTML5和JavaScript库在浏览器端直接生成并下载Excel文件的技术方案。通过引入alasql.js和xlsx.core.min.js两个库,可以轻松实现数据导出功能。 ... [详细]
  • 本文介绍了一种方法,用于创建一个包含中文数据的 Employees 表,并确保在 SQL Server 中能够正确显示和处理中文字符。 ... [详细]
  • CentOS 7.6环境下Oracle 11g的数据泵操作与nmon性能监控
    本文详细介绍在CentOS 7.6操作系统中使用Oracle 11g的数据泵(Data Pump)进行数据的导入导出操作,并介绍如何通过nmon工具进行系统性能的监控与分析。 ... [详细]
  • 本文档详细介绍了如何在MongoDB命令行中执行基本操作,包括数据库的选择与创建、文档的插入与查询、文档的更新与删除等。同时,还涵盖了条件查询、统计、模糊查询等高级功能。 ... [详细]
author-avatar
一种姿态获得无可取代
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有