电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

Oracle?Database?23c新特性之關(guān)聯(lián)更新和刪除示例詳解

瀏覽:87日期:2023-09-22 20:54:42
目錄示例表關(guān)聯(lián)更新關(guān)聯(lián)刪除

Oracle database 23c 開始支持在 UPDATE 和 DELETE 語句中使用 JOIN 連接,獲取更新和刪除的數(shù)據(jù)源。

示例表

本文使用示例表可以通過 GitHub 下載,然后基于 employee 表創(chuàng)建一個(gè) 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 字段全部設(shè)置為 0,用于驗(yàn)證關(guān)聯(lián)更新。

關(guān)聯(lián)更新

我們首先查看一下 emp_devp 中的數(shù)據(jù):

SELECT emp_id, emp_name, salary, bonus, emailFROM emp_devpORDER 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|關(guān)平 | 0.00| |guanping@shuguo.com| 12|趙氏 | 0.00| |zhaoshi@shuguo.com | 13|關(guān)興 | 0.00| |guanxing@shuguo.com| 14|張苞 | 0.00| |zhangbao@shuguo.com| 15|趙統(tǒng) | 0.00| |zhaotong@shuguo.com| 16|周倉 | 0.00| |zhoucang@shuguo.com| 17|馬岱 | 0.00| |madai@shuguo.com |

然后我們通過 emp_id 字段關(guān)聯(lián) employee 表更新 emp_devp 中的數(shù)據(jù),包括 salary、bonus 以及 email,數(shù)據(jù)來自 employee。

UPDATE emp_devp edSET ed.salary = e.salary, ed.bonus = e.bonus, ed.email = e.emailFROM employee e WHERE e.emp_id = ed.emp_id;

Oracle 使用了 UPDATE FROM 語法實(shí)現(xiàn)關(guān)聯(lián)更新,其他數(shù)據(jù)庫可能使用 UPDATE JOIN 語法。

現(xiàn)在我們查看一下更新后的 emp_devp 數(shù)據(jù):

SELECT emp_id, emp_name, salary, bonus, emailFROM emp_devpORDER 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|關(guān)平 | 6800.00| |guanping@shuguo.com| 12|趙氏 | 6600.00| |zhaoshi@shuguo.com | 13|關(guān)興 | 7000.00| |guanxing@shuguo.com| 14|張苞 | 6500.00| |zhangbao@shuguo.com| 15|趙統(tǒng) | 6000.00| |zhaotong@shuguo.com| 16|周倉 | 8000.00| |zhoucang@shuguo.com| 17|馬岱 | 5800.00| |madai@shuguo.com |

在此之前的版本中,我們可以使用子查詢或者 MERGE 語句實(shí)現(xiàn)相同的效果:

UPDATE emp_devp edSET (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 edUSING employee eON (e.emp_id = ed.emp_id)WHEN MATCHED THEN UPDATE SET ed.salary = e.salary, ed.bonus = e.bonus, ed.email = e.email;

如果更新操作的數(shù)據(jù)源來自多個(gè)表,可以通過 JOIN 將它們進(jìn)行連接。以下示例增加了 job 表作為數(shù)據(jù)更新的來源:

UPDATE emp_devp edSET ed.salary = e.salary, ed.bonus = e.bonus, ed.email = e.emailFROM 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 中職位名稱為“程序員”的員工信息。

關(guān)聯(lián)刪除

我們同樣可以基于 employee 中的數(shù)據(jù)刪除 emp_devp 中的員工。以下示例使用 emp_id 作為兩個(gè)表的關(guān)聯(lián)字段,同時(shí)還增加了一個(gè)額外的過濾條件:

DELETE emp_devp edFROM employee eWHERE ed.emp_id = e.emp_idAND e.salary < 10000;

查看 emp_devp 中的數(shù)據(jù):

SELECT emp_id, emp_name, salary, bonus, emailFROM emp_devpORDER BY emp_id;EMP_ID|EMP_NAME|SALARY|BONUS|EMAIL |------+--------+------+-----+------------------+ 9|趙云 | 15000| 6000|zhaoyun@shuguo.com|

如果刪除操作的數(shù)據(jù)源來自多個(gè)表,可以通過 JOIN 將它們進(jìn)行連接。以下示例增加了 job 表作為數(shù)據(jù)刪除的來源:

DELETE emp_devp edFROM employee eJOIN job j ON j.job_id = e.job_idWHERE ed.emp_id = e.emp_idAND j.job_title = '開發(fā)經(jīng)理';

到此這篇關(guān)于Oracle Database 23c新特性之關(guān)聯(lián)更新和刪除的文章就介紹到這了,更多相關(guān)Oracle Database 23c內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Oracle 數(shù)據(jù)庫
主站蜘蛛池模板: 招商帮-一站式网络营销服务|互联网整合营销|网络推广代运营|信息流推广|招商帮企业招商好帮手|搜索营销推广|短视视频营销推广 | 气弹簧定制-气动杆-可控气弹簧-不锈钢阻尼器-工业气弹簧-可调节气弹簧厂家-常州巨腾气弹簧供应商 | 烟台条码打印机_烟台条码扫描器_烟台碳带_烟台数据采集终端_烟台斑马打印机-金鹏电子-金鹏电子 | arch电源_SINPRO_开关电源_模块电源_医疗电源-东佑源 | 等离子表面处理机-等离子表面活化机-真空等离子清洗机-深圳市东信高科自动化设备有限公司 | 东莞工厂厂房装修_无尘车间施工_钢结构工程安装-广东集景建筑装饰设计工程有限公司 | 高低温试验房-深圳高低温湿热箱-小型高低温冲击试验箱-爱佩试验设备 | 隔离变压器-伺服变压器--输入输出电抗器-深圳市德而沃电气有限公司 | 免联考国际MBA_在职MBA报考条件/科目/排名-MBA信息网 | 真空泵厂家_真空泵机组_水环泵_旋片泵_罗茨泵_耐腐蚀防爆_中德制泵 | 生物颗粒燃烧机-生物质燃烧机-热风炉-生物颗粒蒸汽发生器-丽水市久凯能源设备有限公司 | 上海新光明泵业制造有限公司-电动隔膜泵,气动隔膜泵,卧式|立式离心泵厂家 | 二手光谱仪维修-德国OBLF光谱仪|进口斯派克光谱仪-热电ARL光谱仪-意大利GNR光谱仪-永晖检测 | 聚氨酯保温钢管_聚氨酯直埋保温管道_聚氨酯发泡保温管厂家-沧州万荣防腐保温管道有限公司 | 佛山商标注册_商标注册代理|专利注册申请_商标注册公司_鸿邦知识产权 | 四川成都干燥设备_回转筒干燥机_脉冲除尘器_输送设备_热风炉_成都川工星科机电设备有限公司 | 西安展台设计搭建_西安活动策划公司_西安会议会场布置_西安展厅设计西安旭阳展览展示 | 广州印刷厂_广州彩印厂-广州艺彩印务有限公司 | TPE塑胶原料-PPA|杜邦pom工程塑料、PPSU|PCTG材料、PC/PBT价格-悦诚塑胶 | 渗透仪-直剪仪-三轴仪|苏州昱创百科 | 合肥宠物店装修_合肥宠物美容院装修_合肥宠物医院设计装修公司-安徽盛世和居装饰 | 十字轴_十字轴万向节_十字轴总成-南京万传机械有限公司 | 佛山市钱丰金属不锈钢蜂窝板定制厂家|不锈钢装饰线条|不锈钢屏风| 电梯装饰板|不锈钢蜂窝板不锈钢工艺板材厂家佛山市钱丰金属制品有限公司 | 艺术生文化课培训|艺术生文化课辅导冲刺-济南启迪学校 | 工业冷却塔维修厂家_方形不锈钢工业凉水塔维修改造方案-广东康明节能空调有限公司 | 工业洗衣机_工业洗涤设备_上海力净工业洗衣机厂家-洗涤设备首页 bkzzy在职研究生网 - 在职研究生招生信息咨询平台 | 浙江宝泉阀门有限公司 | 成都竞价托管_抖音代运营_网站建设_成都SEM外包-成都智网创联网络科技有限公司 | 转向助力泵/水泵/发电机皮带轮生产厂家-锦州华一精工有限公司 | 丁基胶边来料加工,医用活塞边角料加工,异戊二烯橡胶边来料加工-河北盛唐橡胶制品有限公司 | 水质监测站_水质在线分析仪_水质自动监测系统_多参数水质在线监测仪_水质传感器-山东万象环境科技有限公司 | 包装设计公司,产品包装设计|包装制作,包装盒定制厂家-汇包装【官方网站】 | SPC工作站-连杆综合检具-表盘气动量仪-内孔缺陷检测仪-杭州朗多检测仪器有限公司 | 120kv/2mA直流高压发生器-60kv/2mA-30kva/50kv工频耐压试验装置-旭明电工 | 亿立分板机_曲线_锯片式_走刀_在线式全自动_铣刀_在线V槽分板机-杭州亿协智能装备有限公司 | 污水处理设备维修_污水处理工程改造_机械格栅_过滤设备_气浮设备_刮吸泥机_污泥浓缩罐_污水处理设备_污水处理工程-北京龙泉新禹科技有限公司 | 聚丙烯酰胺PAM-聚合氯化铝PAC-絮凝剂-河南博旭环保科技有限公司 巨野电机维修-水泵维修-巨野县飞宇机电维修有限公司 | 合肥抖音SEO网站优化-网站建设-网络推广营销公司-百度爱采购-安徽企匠科技 | 除甲醛公司-甲醛检测治理-杭州创绿家环保科技有限公司-室内空气净化十大品牌 | 氟氨基酮、氯硝柳胺、2-氟苯甲酸、异香兰素-新晨化工 | 塑钢课桌椅、学生课桌椅、课桌椅厂家-学仕教育设备首页 |