KingbaseES数据库merge语法

2024-05-27 08:52

本文主要是介绍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子句

这篇关于KingbaseES数据库merge语法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1007015

相关文章

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

mysql数据库重置表主键id的实现

《mysql数据库重置表主键id的实现》在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,本文主要介绍了mysql数据库重置表主键id的实现,具有一定的参考价值,感兴趣的可以了... 目录关键语法演示案例在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,当我们

C++ 中的 if-constexpr语法和作用

《C++中的if-constexpr语法和作用》if-constexpr语法是C++17引入的新语法特性,也被称为常量if表达式或静态if(staticif),:本文主要介绍C++中的if-c... 目录1 if-constexpr 语法1.1 基本语法1.2 扩展说明1.2.1 条件表达式1.2.2 fa

Spring Boot 整合 MyBatis 连接数据库及常见问题

《SpringBoot整合MyBatis连接数据库及常见问题》MyBatis是一个优秀的持久层框架,支持定制化SQL、存储过程以及高级映射,下面详细介绍如何在SpringBoot项目中整合My... 目录一、基本配置1. 添加依赖2. 配置数据库连接二、项目结构三、核心组件实现(示例)1. 实体类2. Ma

查看Oracle数据库中UNDO表空间的使用情况(最新推荐)

《查看Oracle数据库中UNDO表空间的使用情况(最新推荐)》Oracle数据库中查看UNDO表空间使用情况的4种方法:DBA_TABLESPACES和DBA_DATA_FILES提供基本信息,V$... 目录1. 通过 DBjavascriptA_TABLESPACES 和 DBA_DATA_FILES

Java实现数据库图片上传与存储功能

《Java实现数据库图片上传与存储功能》在现代的Web开发中,上传图片并将其存储在数据库中是常见的需求之一,本文将介绍如何通过Java实现图片上传,存储到数据库的完整过程,希望对大家有所帮助... 目录1. 项目结构2. 数据库表设计3. 实现图片上传功能3.1 文件上传控制器3.2 图片上传服务4. 实现

使用Dify访问mysql数据库详细代码示例

《使用Dify访问mysql数据库详细代码示例》:本文主要介绍使用Dify访问mysql数据库的相关资料,并详细讲解了如何在本地搭建数据库访问服务,使用ngrok暴露到公网,并创建知识库、数据库访... 1、在本地搭建数据库访问的服务,并使用ngrok暴露到公网。#sql_tools.pyfrom

Java实现数据库图片上传功能详解

《Java实现数据库图片上传功能详解》这篇文章主要为大家详细介绍了如何使用Java实现数据库图片上传功能,包含从数据库拿图片传递前端渲染,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、前言2、数据库搭建&nbsChina编程p; 3、后端实现将图片存储进数据库4、后端实现从数据库取出图片给前端5、前端拿到

IDEA连接达梦数据库的详细配置指南

《IDEA连接达梦数据库的详细配置指南》达梦数据库(DMDatabase)作为国产关系型数据库的代表,广泛应用于企业级系统开发,本文将详细介绍如何在IntelliJIDEA中配置并连接达梦数据库,助力... 目录准备工作1. 下载达梦JDBC驱动配置步骤1. 将驱动添加到IDEA2. 创建数据库连接连接参数