oracle 多表連合修改----BYPASS_UJVC(轉)
原文連線:
http://blog.chinaunix.net/u/28618/showart_347103.html
這就是oracle中支援的多表關聯更新中的語法,這種語法比使用子查詢更新效率更高。
[@more@]ORA-01779: cannot modify a column which maps to a non-key-preserved table
例如,使用以下的更新查詢就會出現該錯誤。
CREATE TABLE test1 ( id integer primary key, num integer );
INSERT INTO test1 VALUES (1,0);
INSERT INTO test1 VALUES (2,0);
INSERT INTO test1 VALUES (3,0);
INSERT INTO test1 VALUES (4,0);
CREATE TABLE test2 ( id integer, num integer, upd integer );
INSERT INTO test2 VALUES (1,10, 0);
INSERT INTO test2 VALUES (2,20, 1);
UPDATE ( SELECT t1.id id1, t1.num num1, t2.id id2, t2.num num2
FROM test1 t1, test2 t2 WHERE t1.id=t2.id AND t2.upd=1 )
SET num1=num2; ORA-01779: cannot modify a column which maps to a non-key-preserved table
這個錯誤的意思是,子查詢的結果中,更新資料來源(test2)的內容不唯一,導致被更新物件(test1)中的一行可能對應資料來源(test2)中的多行。 本例中,test2表的id不唯一,因此test2表中可能存在id相同但是num不相同的資料,這種資料是無法用來更新 test1 的。
解決方法就是保證資料來源的唯一性,例如本例中可以為test2.id建立一個唯一索引:
CREATE UNIQUE INDEX test2_idx_001 ON test2 (id);
之後上面的更新就可以執行了。
另外也可以強制 Oracle 執行,方法是加上 BYPASS_UJVC 註釋。
UPDATE
( SELECT /*+ BYPASS_UJVC */ t1.id id1, t1.num num1, t2.id id2, t2.num num2
FROM test1 t1, test2 t2
WHERE t1.id=t2.id AND t2.upd=1 )
SET num1=num2;
BYPASS_UJVC的作用是跳過Oracle的鍵檢查。 這樣雖然能夠執行了,但是如果test2中存在不唯一的資料,test1就會被更新多次而導致意想不到的結果。
方法二:
update (select /*+ BYPASS_UJVC */ name , rname
from table1 t1, table2 t2
where t1.id = t2.id
and t1.id is not null)
set name = rname
-- 對應的MERGE格式()
-- 只更新不插入的語法 只有10g才能支援,9i還不能支援!
-- 因此如果是9i,則還是要使用對檢視的UPDATE語句
MERGE INTO david_1 T1
USING david_2 T2
ON (T1.A = T2.A AND t1.a <=2)
WHEN MATCHED THEN
UPDATE
SET T1.B = T2.B
--WHEN NOT MATCHED THEN NOTHING
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/19602/viewspace-1043411/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- oracle hint /*+ BYPASS_UJVC*/ 使用案例Oracle
- 多表的連線
- oracle多表插入Oracle
- thinkPHP多表聯合查詢PHP
- oracle心得4--集合查詢@oracle中的多表連線@案例分析Oracle
- 多表外連線的使用
- JPA 之 多表聯合查詢
- Oracle查詢轉換(三)外連線檢視合併Oracle
- Oracle-多表查詢Oracle
- Oracle多表插入語句Oracle
- LEFT JOIN 和JOIN 多表連線
- 【janes】多表查詢 外連線
- oracle資料庫修改連線數Oracle資料庫
- MySQL筆記3——內連線/外連線、多表連線MySql筆記
- 檢視並修改oracle最大連線數Oracle
- ORACLE檢視並修改最大連線數Oracle
- SQL語言基礎(多表連線)SQL
- Sql Server系列:多表連線查詢SQLServer
- SQL複雜查詢多表連線SQL
- Oracle 多表關聯刪除Oracle
- Oracle的多表插入語句Oracle
- mybatis多表聯合查詢的寫法MyBatis
- Oracle的表連線方法(一)排序合併連線Oracle排序
- MySQL學習筆記之多表連線MySql筆記
- 多表連線SQL優化如何處理SQL優化
- ORACLE多表關聯UPDATE語句Oracle
- ORACLE多表關聯UPDATE 語句Oracle
- 多表關聯更新(mysql,oracle,postgreSQL)MySqlOracle
- 多表聯合查詢 - 基於註解SQLSQL
- Oracle ODI 12c之多表聯合查詢以及定時任務設定Oracle
- 【轉】修改Oracle字符集(character set)Oracle
- 【轉】怎樣修改Oracle的SIDOracle
- Linux下Oracle重啟和修改連線數LinuxOracle
- Hadoop--Map/Reduce實現多表連結Hadoop
- jpa動態查詢與多表聯合查詢
- Oracle表連線操作——Merge Sort Join(合併排序連線)Oracle排序
- Oracle多表關聯更新的語法Oracle
- oracle insert all多表插入的示例Oracle