如何將兩個資料庫資料插入到另一個資料庫? |
答題得分者是:Fishman
|
wwwbbs
初階會員 發表:41 回覆:59 積分:25 註冊:2003-05-23 發送簡訊給我 |
|
Stallion
版主 發表:52 回覆:1600 積分:1995 註冊:2004-09-15 發送簡訊給我 |
|
Fishman
尊榮會員 發表:120 回覆:1949 積分:2163 註冊:2006-10-28 發送簡訊給我 |
Hi wwwbbs,
insert into c.dbo.c1 (pk_field, filed1, field2, field3, ...) select pk_field, filed1, filed2 filed3, ... from a.dbo.a1 union all select pk_field 100, filed1, filed2 filed3, ... from b.dbo.b1其中100為a.dbo.a1 table 中 PK 值最大者,如此即可避免鍵值重複問題(如果沒有其他 Unique Key的話)。 ---------------------------------- 小弟才疏學淺,若有謬誤尚請不吝指教 ----------------------------------
------
Fishman |
wwwbbs
初階會員 發表:41 回覆:59 積分:25 註冊:2003-05-23 發送簡訊給我 |
引言: Hi wwwbbs,insert into c.dbo.c1 (pk_field, filed1, field2, field3, ...) select pk_field, filed1, filed2 filed3, ... from a.dbo.a1 union all select pk_field 100, filed1, filed2 filed3, ... from b.dbo.b1其中100為a.dbo.a1 table 中 PK 值最大者,如此即可避免鍵值重複問題(如果沒有其他 Unique Key的話)。 ---------------------------------- 小弟才疏學淺,若有謬誤尚請不吝指教 ---------------------------------- >>< face="Verdana, Arial, Helvetica"> 感謝Fishman前輩,可否再請問select pk_field 100,的100要如何以變數方式存在,它是依據 select MAX(pk_field) from a.dbo.a1而來,如果得到的是90,那就要從91開始,不知這樣的SQL語法該如何寫? 謝謝! |
Fishman
尊榮會員 發表:120 回覆:1949 積分:2163 註冊:2006-10-28 發送簡訊給我 |
Hi wwwbbs, 試試這樣行不行:
insert into c.dbo.c1 (pk_field, filed1, field2, field3, ...) select pk_field, filed1, filed2 filed3, ... from a.dbo.a1 union all select pk_field (select max(pk_field)) from a.dbo.a1) as newpk_filed, filed1, filed2 filed3, ... from b.dbo.b1---------------------------------- 小弟才疏學淺,若有謬誤尚請不吝指教 ----------------------------------
------
Fishman |
wwwbbs
初階會員 發表:41 回覆:59 積分:25 註冊:2003-05-23 發送簡訊給我 |
引言: Hi wwwbbs, 試試這樣行不行:insert into c.dbo.c1 (pk_field, filed1, field2, field3, ...) select pk_field, filed1, filed2 filed3, ... from a.dbo.a1 union all select pk_field (select max(pk_field)) from a.dbo.a1) as newpk_filed, filed1, filed2 filed3, ... from b.dbo.b1---------------------------------- 小弟才疏學淺,若有謬誤尚請不吝指教 ---------------------------------- >>< face="Verdana, Arial, Helvetica"> 謝謝Fishman前輩,原來我就是少了 as newpk_filed, select pk_field (select max(pk_field)) from a.dbo.a1) as newpk_filed, |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |