程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 編程綜合問答 >> select-SQLServer中如何判斷一條記錄不能存在並使用其他值代替?

select-SQLServer中如何判斷一條記錄不能存在並使用其他值代替?

編輯:編程綜合問答
SQLServer中如何判斷一條記錄不能存在並使用其他值代替?

圖片說明

現有表tableA,tableB。tableA有一列為bid,是通過該列跟tableB中的一行記錄關聯 。
一個存儲過程中的語句如下,作用是獲取A表中的一些信息,並通過bid獲取與其關聯的 tableB中的某一行的信息。(另外,tableB中會有一個aid的列,通過該列和tableA中的一條記錄對應,一條talbeA中的記錄可以對應tableB中多條記錄,以最後更新的那條tableB記錄為綁定)
select tableA.no, talbeA.total, tableB.s1, tableB.s2 from tableA,table B where tableA.bid=tableB.bid

但這樣執行的話,若tableA.bid這一條記錄在talbeB中不存在,則篩選不出數據來。
現在我希望改成,若tableA.bid不存在,則從tableB中找出aid=tableA.aid的最後一條記錄替換給到tableA.bid(id是按1的增量標識插入)。然後再作
select tableA.no, talbeA.total, tableB.s1, tableB.s2 from tableA,table B where tableA.bid=tableB.bid這功能

最佳回答:


 update tableA set bid=(select max(bid) bid from tableB where aid=tableA.aid) 
where bid not in (select bid from tableB)
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved