Oracle SQL——如何用一個表的數據更新另一個表中的數據


背景

  • 一次處理數據的過程中,需要將表A(源表)的數據更新到表B(目標表)中

前提

  • 兩張表一定要有關聯字段
  • 使用關聯字段聯查兩張表時,兩張表關系必須滿足條件:目標表和源表的表間關系一定是多對一或者一對一

使用

  • 基本SQL如下
    update tableA A set A.val = (select val from tableB B where A.idd = B.idd);

擴展

  • 如上SQL中的tableB可以替換成任意一個子查詢,典型的是源表和目標表是同一張表,SQL可以擴展如下
    update tableA A set A.val =select C.val from (select B.val as val,B.idd as idd from tableA B where A.idd=B.idd) C where A.idd=C.idd;
  • 報錯
    • 錯誤:ORA-01427:單行子查詢返回多個行
    • 原因:當前關聯條件下,子查詢返回多條數據,導致目標表和源表的表間關系成為一對多,導致報錯
  • Next


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM