前提
Postgres12
実現したいこと
・2つのテーブルを比較して、片方のテーブルに存在しないデータは追加し、
存在するデータは更新するようにしたい。
→ testテーブルに、tmp_testテーブルからデータを追加したい。
→ 指定の日以降のデータでtestテーブルに存在しないけどtmp_testテーブルには存在するデータを追加したい
発生している問題・エラーメッセージ
意図したレコードが追加されない
該当のソースコード
sql
1INSERT INTO test 2SELECT 3 id 4 ,name 5 ,time_stamp 6FROM 7 tmp_test 8WHERE NOT EXISTS 9 ( 10 select 11 id 12 ,name 13 ,time_stamp 14 from 15 test 16 where 17 time_stamp >= cast( '2022-06-05' as timestamp) 18 ) 19 ON CONFLICT ON CONSTRAINT test_pkey 20 DO UPDATE SET 21 name = excluded.name 22 ,time_stamp = excluded.time_stamp 23;
それぞれのテーブル内容
primary key はtestテーブル側のみ idで指定しています
[testテーブル] id | name | ts ----+------+--------------------- 1 | A | 2022-06-03 01:00:00 2 | B | 2022-06-04 01:00:00 3 | C | 2022-06-04 11:00:00 4 | D | 2022-06-05 20:00:00 5 | Z | 2022-06-03 01:00:00 9 | F | 2022-06-02 01:00:00
[tmp_testテーブル] id | name | ts ----+------+--------------------- 2 | Y | 2022-06-04 23:00:00 5 | Z | 2022-06-03 01:00:00 6 | X | 2022-06-05 01:00:00 9 | F | 2022-06-02 01:00:00
追加されてほしいデータ
上記のsql, テーブルの場合、
2022-06-05 以降のデータでtestテーブルには存在しない
id = 6, name = X, ts = 2022-06-05 01:00:00 の
データのみがtestテーブルに追加されてほしいです。
実際には上記を実行してもレコードは追加されず、
INSERT 0 0で終了してしまいます。

回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2022/06/14 00:58
2022/06/14 02:57
2022/06/15 01:23
2022/06/15 14:26
2022/06/16 01:11