Oracle Database 23c新特性之关联更新和删除示例详解

 更新时间:2023年06月02日 14:36:28   作者:不剪发的Tony老师  
这篇文章主要介绍了Oracle Database 23c新特性之关联更新和删除的相关资料,Oracle database 23c开始支持在UPDATE和DELETE语句中使用JOIN连接,获取更新和删除的数据源,本文结合实例代码给大家介绍的非常详细,需要的朋友可以参考下

Oracle database 23c 开始支持在 UPDATE 和 DELETE 语句中使用 JOIN 连接,获取更新和删除的数据源。

示例表

本文使用示例表可以通过 GitHub 下载,然后基于 employee 表创建一个 emp_devp:

CREATE TABLE emp_devp 
AS 
SELECT * FROM employee e 
WHERE dept_id = 4; 
UPDATE emp_devp 
SET salary = 0;
COMMIT;

emp_devp 中的 salary 字段全部设置为 0,用于验证关联更新。

关联更新

我们首先查看一下 emp_devp 中的数据:

SELECT emp_id, emp_name, salary, bonus, email
FROM emp_devp
ORDER BY emp_id;
emp_id|emp_name|salary|bonus  |email              |
------+--------+------+-------+-------------------+
     9|赵云     |  0.00|6000.00|zhaoyun@shuguo.com |
    10|廖化     |  0.00|       |liaohua@shuguo.com |
    11|关平     |  0.00|       |guanping@shuguo.com|
    12|赵氏     |  0.00|       |zhaoshi@shuguo.com |
    13|关兴     |  0.00|       |guanxing@shuguo.com|
    14|张苞     |  0.00|       |zhangbao@shuguo.com|
    15|赵统     |  0.00|       |zhaotong@shuguo.com|
    16|周仓     |  0.00|       |zhoucang@shuguo.com|
    17|马岱     |  0.00|       |madai@shuguo.com   |

然后我们通过 emp_id 字段关联 employee 表更新 emp_devp 中的数据,包括 salary、bonus 以及 email,数据来自 employee。

UPDATE emp_devp ed
SET ed.salary = e.salary,
    ed.bonus = e.bonus, 
    ed.email = e.email
FROM employee e 
WHERE e.emp_id = ed.emp_id;

Oracle 使用了 UPDATE FROM 语法实现关联更新,其他数据库可能使用 UPDATE JOIN 语法。

现在我们查看一下更新后的 emp_devp 数据:

SELECT emp_id, emp_name, salary, bonus, email
FROM emp_devp
ORDER BY emp_id;
emp_id|emp_name|salary  |bonus  |email              |
------+--------+--------+-------+-------------------+
     9|赵云     |15000.00|6000.00|zhaoyun@shuguo.com |
    10|廖化     | 6500.00|       |liaohua@shuguo.com |
    11|关平     | 6800.00|       |guanping@shuguo.com|
    12|赵氏     | 6600.00|       |zhaoshi@shuguo.com |
    13|关兴     | 7000.00|       |guanxing@shuguo.com|
    14|张苞     | 6500.00|       |zhangbao@shuguo.com|
    15|赵统     | 6000.00|       |zhaotong@shuguo.com|
    16|周仓     | 8000.00|       |zhoucang@shuguo.com|
    17|马岱     | 5800.00|       |madai@shuguo.com   |

在此之前的版本中,我们可以使用子查询或者 MERGE 语句实现相同的效果:

UPDATE emp_devp ed
SET (salary, bonus, email) = (SELECT salary, bonus, email
                              FROM employee e 
                              WHERE e.emp_id = ed.emp_id)
WHERE EXISTS (SELECT 1
              FROM employee e
              WHERE e.emp_id = ed.emp_id);
MERGE INTO emp_devp ed
USING employee e
ON (e.emp_id = ed.emp_id)
WHEN MATCHED THEN 
  UPDATE SET ed.salary = e.salary,
             ed.bonus = e.bonus,
             ed.email = e.email;

如果更新操作的数据源来自多个表,可以通过 JOIN 将它们进行连接。以下示例增加了 job 表作为数据更新的来源:

UPDATE emp_devp ed
SET ed.salary = e.salary,
    ed.bonus = e.bonus, 
    ed.email = e.email
FROM employee e 
JOIN job j ON (e.job_id = j.job_id AND j.job_title = '程序员')
WHERE e.emp_id = ed.emp_id;

以上语句只会更新 emp_devp 中职位名称为“程序员”的员工信息。

关联删除

我们同样可以基于 employee 中的数据删除 emp_devp 中的员工。以下示例使用 emp_id 作为两个表的关联字段,同时还增加了一个额外的过滤条件:

DELETE emp_devp ed
FROM employee e
WHERE ed.emp_id = e.emp_id
AND e.salary < 10000;

查看 emp_devp 中的数据:

SELECT emp_id, emp_name, salary, bonus, email
FROM emp_devp
ORDER BY emp_id;
EMP_ID|EMP_NAME|SALARY|BONUS|EMAIL             |
------+--------+------+-----+------------------+
     9|赵云     | 15000| 6000|zhaoyun@shuguo.com|

如果删除操作的数据源来自多个表,可以通过 JOIN 将它们进行连接。以下示例增加了 job 表作为数据删除的来源:

DELETE emp_devp ed
FROM employee e
JOIN job j ON j.job_id = e.job_id
WHERE ed.emp_id = e.emp_id
AND j.job_title = '开发经理';

到此这篇关于Oracle Database 23c新特性之关联更新和删除的文章就介绍到这了,更多相关Oracle Database 23c内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • oracle合并列的函数wm_concat的使用详解

    oracle合并列的函数wm_concat的使用详解

    本篇文章是对oracle合并列的函数wm_concat的使用进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • Oracle中的SUM用法讲解

    Oracle中的SUM用法讲解

    今天小编就为大家分享一篇关于Oracle中的SUM用法讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-04-04
  • Oracle中如何处理空值函数(NVL、NVL2、NULLIF等)详解

    Oracle中如何处理空值函数(NVL、NVL2、NULLIF等)详解

    本文详细介绍了Oracle数据库中处理空值的常用函数,包括NVL()、NVL2()、NULLIF()、COALESCE()及DECODE()和CASE()函数,这些函数在数据库查询和数据处理中发挥重要作用,帮助开发者有效处理空值问题,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-11-11
  • navicat使用Oracle创建库以及用户超详细教程

    navicat使用Oracle创建库以及用户超详细教程

    本文介绍如何使用Navicat连接Oracle数据库,步骤包括准备工作、新建连接、输入用户名和密码、测试连接、建立库和用户、授权以及测试的相关资料,需要的朋友可以参考下
    2024-09-09
  • Linux中Oracle安装后bash: sqlplus: command not found问题解决方法

    Linux中Oracle安装后bash: sqlplus: command not found问题解决方法

    这篇文章主要给大家介绍了关于Linux中Oracle安装后bash: sqlplus: command not found问题的解决方法,这是因为你的系统中没有安装Oracle数据库客户端或者其可执行文件路径未配置到,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-06-06
  • 详解Oracle 中实现数据透视表的几种方法

    详解Oracle 中实现数据透视表的几种方法

    这篇文章主要介绍了详解Oracle 中实现数据透视表的几种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • Oracle数据库集复制方法浅议

    Oracle数据库集复制方法浅议

    Oracle数据库集复制方法浅议...
    2007-03-03
  • Linux下修改Oracle监听地址的方法

    Linux下修改Oracle监听地址的方法

    这篇文章主要介绍了Linux下修改Oracle监听地址的方法,需要的朋友可以参考下
    2017-10-10
  • Oracle占用内存过高的问题及解决

    Oracle占用内存过高的问题及解决

    这篇文章主要介绍了Oracle占用内存过高的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • Oracle数据库在指定字段后新增字段代码举例

    Oracle数据库在指定字段后新增字段代码举例

    很多时候数据库中已有表的字段与需求业务所需字段有差异,需要增加一个或多个字段,这篇文章主要给大家介绍了关于Oracle数据库在指定字段后新增字段的相关资料,需要的朋友可以参考下
    2023-09-09

最新评论