亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Oracle數(shù)據(jù)庫兩表關(guān)聯(lián)更新的問題

 更新時(shí)間:2023年11月03日 14:42:01   作者:Hvitur  
需要寫一個更新語句,但是更新的判斷條件是兩個表關(guān)聯(lián)查詢出來的,本文通過實(shí)例代碼給大家講解Oracle數(shù)據(jù)庫兩表關(guān)聯(lián)更新的問題及遇到的坑,感興趣的朋友一起看看吧

先放結(jié)論

 UPDATE 需要更新的表名 B
    SET B.更新字段1 = '更新內(nèi)容1', B.更新字段2 = '更新內(nèi)容2'
  WHERE EXISTS (SELECT 1
           FROM 關(guān)聯(lián)表名 A
          WHERE A.關(guān)聯(lián)字段 = B.關(guān)聯(lián)字段
            AND A.篩選字段1 = '篩選字段1' 
            AND A.篩選字段2 = '篩選字段2' 
            AND B.篩選字段3 = '篩選字段3' 
         );

問題分析

需要寫一個更新語句,但是更新的判斷條件是兩個表關(guān)聯(lián)查詢出來的

踩坑一

一開始是打算UPDATE寫兩個表,然后WHERE里面兩表關(guān)聯(lián),就像這樣:

--錯誤sql
UPDATE 表名1 A,表名2 B
    SET A.更新字段1 = '更新內(nèi)容1', A.更新字段2 = '更新內(nèi)容2'
  WHERE A.關(guān)聯(lián)字段 = B.關(guān)聯(lián)字段
   		AND A.篩選字段1 = '篩選字段1' 
        AND A.篩選字段2 = '篩選字段2' 
        AND B.篩選字段3 = '篩選字段3' 

但是一直報(bào)錯
很明顯也不是缺失SET 關(guān)鍵字的問題

在這里插入圖片描述

踩坑二

之后搜索怎么在Oracel關(guān)聯(lián)兩表更新。發(fā)現(xiàn)了下面這種寫法

--正常sql
UPDATE 更新表名 A
   SET A.更新字段1 = '更新內(nèi)容1'
 WHERE EXISTS (SELECT 1 FROM 關(guān)聯(lián)表名 B WHERE A.關(guān)聯(lián)字段 = B.關(guān)聯(lián)字段)

但是也是沒太仔細(xì)看,加上思維固化,寫成了下面這種情況

--錯誤sql
UPDATE 更新表名 A
   SET A.更新字段1 = '更新內(nèi)容1'
 WHERE EXISTS (SELECT 1
          FROM 更新表名 A, 關(guān)聯(lián)表名 B
         WHERE A.關(guān)聯(lián)字段 = B.關(guān)聯(lián)字段
           AND A.篩選字段1 = '篩選字段1')

可以看到在FROM里面比搜索出來的sql語句,多了更新的表名A

顯而易見,還會有點(diǎn)問題
但是這次并不是報(bào)錯,而是篩選不是自己預(yù)想的篩選,導(dǎo)致更新的數(shù)據(jù)非常多

像下圖一樣,更新語句跑了1分半,更新了46萬條數(shù)據(jù)。。。
明顯是有問題的(實(shí)際上只需要更新幾十條),被更新的B表實(shí)際上也只有26萬條數(shù)據(jù),不知道46萬條更新怎么來的
只能先回滾更新

在這里插入圖片描述

通過對比發(fā)現(xiàn)是FROM多寫了個更新的表名,修改之后可以正常的更新,沒有問題

在這里插入圖片描述

踩坑三

既然已經(jīng)可以兩表關(guān)聯(lián)查詢,更新其中一個表了,那能不能同時(shí)更新兩個表呢?

想當(dāng)然的認(rèn)為sql應(yīng)該是這樣的

UPDATE 更新表1 A
   SET A.更新字段1 = 'A表更新內(nèi)容1' ,B.更新字段2 = 'B表更新內(nèi)容2'
 WHERE EXISTS (SELECT 1
          FROM 更新表2 B
         WHERE A.關(guān)聯(lián)字段 = B.關(guān)聯(lián)字段
           AND A.篩選字段 = '篩選字段')

于是寫出了下面的sql,但是事實(shí)證明這樣寫是不行的

在這里插入圖片描述

語句分析

 UPDATE 需要更新的表名 B
    SET B.更新字段1 = '更新內(nèi)容1', B.更新字段2 = '更新內(nèi)容2'
  WHERE EXISTS (SELECT 1
           FROM 關(guān)聯(lián)表名 A
          WHERE A.關(guān)聯(lián)字段 = B.關(guān)聯(lián)字段
            AND A.篩選字段1 = '篩選字段1' 
            AND A.篩選字段2 = '篩選字段2' 
            AND B.篩選字段3 = '篩選字段3' 
         );

A表和B表都有相同的關(guān)聯(lián)字段,并且通過篩選字段校驗(yàn)。那么就有SELECT 1,那么EXISTS就會返回TRUE;最后進(jìn)行更新操作。

EXISTS

EXISTS用于檢查子查詢是否至少會返回一行數(shù)據(jù),該子查詢實(shí)際上并不返回任何數(shù)據(jù),而是返回值True或False

EXISTS(包括 NOT EXISTS )子句的返回值是一個BOOL值。 EXISTS內(nèi)部有一個子查詢語句(SELECT … FROM…), 我將其稱為EXISTS的內(nèi)查詢語句。其內(nèi)查詢語句返回一個結(jié)果集。 EXISTS子句根據(jù)其內(nèi)查詢語句的結(jié)果集空或者非空,返回一個布爾值。

此時(shí)在該更新sql中

--EXISTS的內(nèi)查詢語句為:
SELECT 1
 FROM 關(guān)聯(lián)表名 A
WHERE A.關(guān)聯(lián)字段 = B.關(guān)聯(lián)字段
  AND A.篩選字段1 = '篩選字段1' 
  AND A.篩選字段2 = '篩選字段2' 
  AND B.篩選字段3 = '篩選字段3' 
--WHERE判斷EXISTS返回的BOOL值來決定是否更新
WHERE EXISTS

SELECT 1

當(dāng)我們只關(guān)心數(shù)據(jù)表有多少記錄行而不需要知道具體的字段值時(shí),SELECT 1 FROM TABLE是一個很不錯的SQL語句寫法,它通常用于子查詢。

SELECT 1 FROM TABLE可以減少系統(tǒng)開銷,提高運(yùn)行效率。因?yàn)榇藭r(shí)數(shù)據(jù)庫就不會去檢索數(shù)據(jù)表里每條具體的記錄和每條記錄里每個具體的字段值并將它們放到內(nèi)存里,而是查詢到有多少記錄行存在就輸出多少個“1”,每個“1”代表有1行記錄。

選用數(shù)字1是因?yàn)樗加玫膬?nèi)存空間最小,用數(shù)字0的效果也一樣,即:SELECT 0 FROM TABLE。

從效率上來說,SELECT 1 > SELECT 字段 > SELECT *

在子查詢中的應(yīng)用
常規(guī)寫法

SELECT * FROM t1 a WHERE EXISTS (SELECT * FROM t2 b WHERE a.id = b.id)

更優(yōu)寫法

SELECT * FROM t1 a WHERE EXISTS (SELECT 1 FROM t2 b WHERE a.id = b.id)

到此這篇關(guān)于Oracle數(shù)據(jù)庫兩表關(guān)聯(lián)更新的文章就介紹到這了,更多相關(guān)Oracle兩表關(guān)聯(lián)更新內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論