全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:1047
推到 Plurk!
推到 Facebook!

如何將兩個資料庫資料插入到另一個資料庫?

答題得分者是:Fishman
wwwbbs
初階會員


發表:41
回覆:59
積分:25
註冊:2003-05-23

發送簡訊給我
#1 引用回覆 回覆 發表時間:2005-10-01 00:01:29 IP:220.229.xxx.xxx 未訂閱
現有A、B、C三個資料庫在MS SQL Server2000,其資料結構一模一樣,現在要從A、B資料庫的A1、B1 Table Select出來的資料插入到C資料庫的C1 Table內,如果只轉A資料庫是用SELECT INTO,但插入A資料後再插入B資料時會有鍵值重複的問題,請問要如何解決呢? PK欄位是一個序號值,例如A從001~100,B從001~50,希望插入到C之後序號會重編為001~150。 不知道這樣表達清不清楚。
Stallion
版主


發表:52
回覆:1600
積分:1995
註冊:2004-09-15

發送簡訊給我
#2 引用回覆 回覆 發表時間:2005-10-01 10:32:11 IP:211.22.xxx.xxx 未訂閱
嗯~應該清楚! 在轉換完成
Fishman
尊榮會員


發表:120
回覆:1949
積分:2163
註冊:2006-10-28

發送簡訊給我
#3 引用回覆 回覆 發表時間:2005-10-01 11:57:16 IP:210.65.xxx.xxx 未訂閱
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

發送簡訊給我
#4 引用回覆 回覆 發表時間:2005-10-02 16:22:48 IP:220.229.xxx.xxx 未訂閱
引言: 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

發送簡訊給我
#5 引用回覆 回覆 發表時間:2005-10-03 07:46:35 IP:210.65.xxx.xxx 未訂閱
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

發送簡訊給我
#6 引用回覆 回覆 發表時間:2005-10-04 00:10:58 IP:220.229.xxx.xxx 未訂閱
引言: 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,
系統時間:2024-05-19 21:21:55
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!