当前位置: 首页 > news >正文

Oracle之Merge into函数使用

Merge into函数为Oracle 9i添加的语法,用来合并update和insert语句。所以也经常用于update语句的查询优化:
一、语法格式:

merge into A
using B
on (A.a = B.a) --注意on后面带括号,且不能更新join的字段
when matched then 
update set A.b = B.b 
when not matched then 
insert A (A.a,A.b) values (B.a,B.b) --也可以做delete语句

二、性能方面:Merge into优于update,Merge into只扫描一次全表,Update子句扫描两次;
三、使用需要注意的地方:
①update通常与exists搭配使用,更新指定范围的数据,而不是所有数据;
②改写update语句时,有多个表的情况,分析各个表的之间的关系,写到on后面做关联;
③不等式的,条件子句含不等式时,通常需要将子句做转化到B表中,外层再做关联。

http://www.lryc.cn/news/526148.html

相关文章:

  • 深度解析:哪种心磁图技术是心脏检查的精准之选?
  • SpringBoot--基本使用(配置、整合SpringMVC、Druid、Mybatis、基础特性)
  • 单片机-STM32 IIC通信(OLED屏幕)(十一)
  • 观察者模式 - 观察者模式的应用场景
  • 【C++】详细讲解继承(下)
  • 消息队列篇--原理篇--Pulsar(Namespace,BookKeeper,类似Kafka甚至更好的消息队列)
  • 扬帆数据结构算法之舟,启航C++探索征途——LeetCode深度磨砺:顺序表技术精进实践
  • 基于本地事务表+MQ实现分布式事务
  • 数据结构:二叉树—面试题(一)
  • 【Wordpress网站制作】切换语言的问题
  • 【第二天】零基础入门刷题Python-算法篇-数据结构与算法的介绍-五种常见的排序算法(持续更新)
  • Neural networks 神经网络
  • 汽车免拆诊断案例 | 2007 款日产天籁车起步加速时偶尔抖动
  • 代码随想录day3
  • Spring 面试题【每日20道】【其一】
  • leetcode刷题记录(八十九)——35. 搜索插入位置
  • Flutter 与 React 前端框架对比:深入分析与实战示例
  • 基于Docker的Spark分布式集群
  • Web 代理、爬行器和爬虫
  • MySQL 事件调度器
  • 直线拟合例子 ,岭回归拟合直线
  • Flutter android debug 编译报错问题。插件编译报错
  • 关于IPD流程的学习理解和使用
  • C# 类(Class)
  • Jenkins pipline怎么设置定时跑脚本
  • PostgreSQL模糊查询相关学习参考
  • 【电脑无法通过鼠标和键盘唤醒应该怎么办】
  • Java 大视界 -- Java 大数据中的数据脱敏技术与合规实践(60)
  • Vue3.5 企业级管理系统实战(三):页面布局及样式处理 (Scss UnoCSS )
  • 【xcode 16.2】升级xcode后mac端flutter版的sentry报错