複数列をキーにしている場合、IN()は使えないのでexistsを使う。
where not exists ()の中で「SELECT *」を指定していますがあまり意味はなく、アーカイブテーブルと本テーブルのテーブル定義が違っていてもexists()は使えます。
今回サンプルとしたtSecテーブルは、[通貨ペアNo]と[日時]の2列が主キーでした。
1 2 3 4 5 6 7 8 |
SELECT * FROM FX_ACV.hstr.tSec as a where not exists ( SELECT * FROM FX.hstr.tSec as b where (a.[通貨ペアNo] = b.[通貨ペアNo] and a.[日時] = b.[日時]) ) |
アーカイブDBに有って本DBには無いデータを全て、本DBへInsertするSQLはこんな感じ。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
INSERT INTO FX.hstr.tSec (通貨ペアNo ,日時 ,買いRate ,売りRate) SELECT 通貨ペアNo ,日時 ,Rate_買い ,Rate_売り FROM FX_ACV.hstr.tSec as a where not exists ( SELECT * FROM FX.hstr.tSec as b where (a.通貨ペアNo = b.通貨ペアNo and a.日時 = b.StartDate) ) |
コメント