KingbaseES数据库merge语法


数据库版本:KingbaseES V008R006C008B0014


简介

    MERGE 语句是一种用于数据操作的 SQL 语句,它能够根据指定的条件将 INSERT、UPDATE 和 DELETE 操作结合到单个语句中。其主要作用是在目标表和源表之间进行数据比较和同步,根据条件的匹配情况来执行不同的操作。使用 MERGE 语法可合并 UPDATE 和 INSERT 语句,相比于单独执行 UPDATE + INSERT 语句效率更高。

        

目录

1. 语法说明

2. 基础用法

2.1. insert子句

2.2. update子句

2.3. delete子句


        

1. 语法说明

  • 花括号表示必选
  • 方括号表示可选
MERGE INTO[模式.] {目标表} [分区名] | 子查询
USING[模式.] {源表} [分区名] | 子查询
ON(条件表达式)
[WHEN MATCHED THEN]--合并update子句
[WHEN NOT MATCHED THEN]--合并insert子句
;

 合并子句的2种语法:

  • WHEN MATCHED THEN:如果条件匹配有相同的数据,那么执行update子句
  • WHEN NOT MATCHED THEN:如果条件匹配 "源表" > "目标表",那么执行insert子句n次

        

合并update子句如下:

WHEN MATCHED THENUPDATE SET 列 = xxx...

合并insert子句如下:

WHEN NOT MATCHED THENINSERT[列名1, 列名2...]VALUES(值1, 值2...)

合并delete子句如下:

DELETE where_clause

        

2. 基础用法

2.1. insert子句

insert 子句语法为:

WHEN NOT MATCHED THENinsert子句

规则:

表达式对多表的列数据进行去重后比较,当出现n次不同数据时,且 "目标表" 小于 "源表",执行 n 次 insert 子句,反之不执行。

        

【案例】用 id 作为 on(表达式),t1 表2行数据、t2 表4行数据,使用 id 列作为条件比较

merge语句如下(向目标表插入数据):

MERGE INTO t1 USING t2    -- 目标表为t1
ON (t1.id = t2.id)        -- 条件表达式
WHEN NOT MATCHED THEN     -- insert子句固定语法insert values(3, 30, '2000-01-03');  --执行insert操作

可以看到插入了2条数据。这是因为 t1.id 和 t2.id 有2行不相同(t2 的3/4),所以插入了2行。

        

使用刚才的语句继续执行1次

这次只插入了1行数据。这是因为上次插入的id中包含3,此时 t1.id 包含 1/2/3,t2.id 包含 1/2/3/4,它们之间只有1处不相同,所以只能插入1行。

        

通过如上案例,可以得出如下结论:merge语句是通过 on(条件表达式) 来判断是否执行 insert 子句向目标表插入数据(将表达式的列数据去重后做比较):

  • 当 "源表" 与 "目标表" 的条件列数据相同时,无法向目标表插入数据;
  • 当 "源表" 与 "目标表" 的条件列有n行不同时:
    • "源表" > "目标表" 时,可以向目标表插入n条数据。
    • "源表" < "目标表" 时,无法插入数据。

        

2.2. update子句

update 子句语法为:

WHEN MATCHED THENupdate子句

规则

表达式对多表的列数据进行去重后比较,当出现n次相同数据时,执行n次update语句

        

【案例一】用 id 作为 on(表达式),两张表存在相同的数据

merge语句如下(更新目标表数据):

MERGE INTO t1 USING t2    -- 目标表为t1
ON (t1.id = t2.id)        -- 条件表达式
WHEN MATCHED THEN         -- update子句固定语法update set t1.amount = t1.amount + 1;  --执行update操作

两张表比较后存在相同的数据,执行 update 子句

        

【案例二】用 id 作为 on(表达式),两张表不存在相同的数据

执行与上述相同的 merge 语句

MERGE INTO t1 USING t2    -- 目标表为t1
ON (t1.id = t2.id)        -- 条件表达式
WHEN MATCHED THEN         -- update子句固定语法update set t1.amount = t1.amount + 1;  --执行update操作

未更新,因为相同的值为0,所以不执行。

        

通过上述案例,可以得出以下结论:

  • 当匹配列没有相同数据时,不执行 update 子句;
  • 当匹配列存在相同数据时,执行 update 子句。

注意:这里的 update 不能更新 on(条件表达式) 的列。比例 on(t1.id = t2.id),则不能更新 id 列。

        

2.3. delete子句

delete 子句与 update 条件和规则一样,存在相同的数据时执行,不存在则不执行

WHEN MATCHED THENupdate子句

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/841947.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

高效并发编程:Java阻塞队列深度解析与最佳实践

1.阻塞队列的基本概念与应用场景 1.1 阻塞队列的定义 阻塞队列&#xff08;BlockingQueue&#xff09;是Java并发包中的一个接口&#xff0c;它支持两个附加操作&#xff1a;当队列为空时&#xff0c;获取元素的线程会等待队列变为非空&#xff1b;当队列满时&#xff0c;存储…

RAG概述(二):Advanced RAG 高级RAG

目录 概述 Advanced RAG Pre-Retrieval预检索 优化索引 增强数据粒度 粗粒度 细粒度 展开说说 优化索引 Chunk策略 Small2Big方法 元数据 引入假设性问题 对齐优化 混合检索 查询优化 查询扩展 查询转换 Post-Retrieval后检索 参考 概述 Native RAG&#…

转义字符知识点

转义字符的使用 什么是转义字符&#xff1f; 它是字符串的一部分&#xff0c;用来表示一些特殊含义的字符 比如&#xff1a;在字符串中表现&#xff0c;单引号&#xff0c;引号&#xff0c;空行等等 固定写法 \字符 不同的\和字符的组合表示不同的含义. 常用的转义字符 附…

关于Springboot同时上传文件与其他参数

Springboot同时上传文件与其他参数 http请求数据传递分为请求体和请求参数。跟在url后面的为请求参数&#xff0c;文件上传和json数据放在请求体中。请求参数格式固定&#xff0c;后台可直接解析&#xff1b;请求体中的数据后台需要根据content-type字段按照特定格式解析。con…

shell从入门到精通(23)贪婪匹配、非贪婪以及独占模式

文章目录 贪婪与非贪婪的区别示例贪婪匹配的特点--自动回溯以满足匹配独占模式总结贪婪与非贪婪的区别 在正则表达式中,贪婪匹配和非贪婪匹配是指匹配模式下的不同行为。 贪婪匹配: 贪婪匹配会尽可能多地匹配符合模式的字符。换句话说,它会一直匹配直到无法再匹配为止。例…

springboot vue 开源 会员收银系统 (4) 门店模块开发

前言 完整版演示 前面我们对会员系统 springboot vue 开源 会员收银系统 (3) 会员管理的开发 实现了简单的会员添加 下面我们将从会员模块进行延伸 门店模块的开发 首先我们先分析一下常见门店的管理模式 常见的管理形式为总公司 - 区域管理&#xff08;若干个门店&#xff…

Java实现插入排序、冒泡排序、堆排序、希尔排序、选择排序、优先队列排序、快速排序、归并排序(详细注释,原理解析)

插入排序 package learn;import java.util.Arrays;/** 每次都将当前元素插入到左侧已经排序的数组中&#xff0c;使得插入之后左侧数组依然有序。* 速度优于选择排序*/ public class InsertSort {public static void insertSort(int[] a) {int n a.length;for (int i 1; i &…

Elasticsearch优点和缺点以及要点和难点具体应用

Elasticsearch是一个开源、分布式、实时的搜索和分析引擎,它位于Elastic Stack(以前称为ELK Stack)的核心。以下是关于Elasticsearch的一些主要特点和功能: 1.分布式和可扩展性:Elasticsearch是分布式的,可以轻松扩展到多个节点以处理大规模数据集和高并发请求。通过将数…

C语言 | Leetcode C语言题解之第113题路径总和II

题目&#xff1a; 题解&#xff1a; int** ret; int retSize; int* retColSize;int* path; int pathSize;typedef struct {struct TreeNode* key;struct TreeNode* val;UT_hash_handle hh; } hashTable;hashTable* parent;void insertHashTable(struct TreeNode* x, struct Tr…

C++干货 --类和对象(二)

前言&#xff1a; 上文中&#xff0c;我们介绍了类这一重要知识点&#xff0c;包括为什么要有类、类的使用方法、封装、以及对象实例化。详情可以去看我的文章&#xff1a;写文章-CSDN创作中心C干货 --类和对象(一)-CSDN博客写文章-CSDN创作中心 这篇文章&#xff0c;我们简单…

我学会了用插件来辅助PostgreSQL,可拷,很刑!

作者&#xff1a;IT邦德 中国DBA联盟(ACDU)成员&#xff0c;10余年DBA工作经验&#xff0c; Oracle、PostgreSQL ACE CSDN博客专家及B站知名UP主&#xff0c;全网粉丝10万 擅长主流Oracle、MySQL、PG、高斯及Greenplum备份恢复&#xff0c; 安装迁移&#xff0c;性能优化、故障…

【蓝桥杯省赛真题44】python计算N+N的值 中小学青少年组蓝桥杯比赛 算法思维python编程省赛真题解析

目录 python计算NN的值 一、题目要求 1、编程实现 2、输入输出 二、算法分析 三、程序编写 四、程序说明 五、运行结果 六、考点分析 七、 推荐资料 1、蓝桥杯比赛 2、考级资料 3、其它资料 python计算NN的值 第十四届蓝桥杯青少年组python省赛真题 一、题目要求…

Makefile学习笔记18|u-boot顶层Makefile04

Makefile学习笔记18|u-boot顶层Makefile04 希望看到这篇文章的朋友能在评论区留下宝贵的建议来让我们共同成长&#xff0c;谢谢。 这里是目录 C语言标准 # With the move to GCC 6, we have implicitly upgraded our language # standard to GNU11 (see https://gcc.gnu.org/…

WordPress--解决迁移后页面404(打不开)的问题

原文网址&#xff1a;WordPress--解决迁移后页面404的问题_IT利刃出鞘的博客-CSDN博客 简介 本文介绍WordPress迁移后部分页面404(打不开)的解决方案。 方案&#xff1a;修改固定链接 简介 要在刚建好网站&#xff0c;还没导入数据之前修改固定链接&#xff0c;否则可能导…

【教学类-58-05】黑白三角拼图05(2-10宫格,每个宫格随机1张-6张,带空格纸,1页3张黑白3张白卡)

背景需求&#xff1a; 【教学类-58-04】黑白三角拼图04&#xff08;2-10宫格&#xff0c;每个宫格随机1张-6张&#xff0c;带空格纸&#xff0c;1页6张黑白&#xff0c;1张6张白卡&#xff09;-CSDN博客文章浏览阅读582次&#xff0c;点赞16次&#xff0c;收藏3次。【教学类-58…

Mac安装pytorch

先下载 Anaconda | The Operating System for AI 网速慢&#xff0c;用中国大陆镜像&#xff1a;NJU Mirror 之前装python3时用的是pip3&#xff0c;这里说一下这pip与conda的区别 Conda和pip都是Python包管理工具&#xff0c;用于安装和管理Python包 包管理范围&#xff1a…

汽车数据应用构想(一)

自从电动汽车GB/T32960标准颁布&#xff0c;要求所有电动汽车必须上传数据开始&#xff0c;各车厂就开始花费大量的人力物力&#xff0c;用于数据的上传与存储。同时随着智能化、网联化的趋势&#xff0c;不断丰富上传数据的内容与数量。数据已成为车厂的重要资产&#xff0c;但…

Day16

Day16 一、迭代器 深入迭代器-foreach的底层 for (String element : list) {System.out.println(element);}底层&#xff1a; //使用foreach循环遍历集合的底层实现&#xff1a;String element;for(Iterator it list.iterator();it.hasNext();System.out.println(element))e…

微服务:eureka的搭建,以及服务注册、服务发现、负载均衡

eureka 搭建 新建一个Module,maven项目&#xff0c;导入依赖。 <dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-server</artifactId></dependency><…

月入10万+管道收益,揭秘旅游卡运营的5个阶段!

网上的项目确实繁多&#xff0c;只要深入研究&#xff0c;总能找到适合自己的赚钱方式。在互联网上运营&#xff0c;关键在于理解其底层逻辑。旅游卡项目&#xff0c;就是一个能实现月入10万的实例。接下来&#xff0c;我将为你揭密旅游卡运营的5个阶段&#xff1a; 1、先赚成…