質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
87.20%
INSERT

INSERTとは、行を追加する、コンピュータのデータベース言語SQLにおけるデータ操作言語(DML)ステートメントの1つである

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

解決済

sqlで複数テーブルを比較して、存在しないデータを片方のテーブルにinsert intoしたい。

000mm
000mm

総合スコア6

INSERT

INSERTとは、行を追加する、コンピュータのデータベース言語SQLにおけるデータ操作言語(DML)ステートメントの1つである

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

1回答

0評価

0クリップ

176閲覧

投稿2022/06/13 09:57

編集2022/06/16 10:11

前提

Postgres12

実現したいこと

・2つのテーブルを比較して、片方のテーブルに存在しないデータは追加し、
存在するデータは更新するようにしたい。

 → testテーブルに、tmp_testテーブルからデータを追加したい。

  → 指定の日以降のデータでtestテーブルに存在しないけどtmp_testテーブルには存在するデータを追加したい

発生している問題・エラーメッセージ

意図したレコードが追加されない

該当のソースコード

sql

INSERT INTO test SELECT id ,name ,time_stamp FROM tmp_test WHERE NOT EXISTS ( select id ,name ,time_stamp from test where time_stamp >= cast( '2022-06-05' as timestamp) ) ON CONFLICT ON CONSTRAINT test_pkey DO UPDATE SET name = excluded.name ,time_stamp = excluded.time_stamp ;

それぞれのテーブル内容

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で終了してしまいます。

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

気になる質問をクリップする

クリップした質問は、後からいつでもマイページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

まだ回答がついていません

会員登録して回答してみよう

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
87.20%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問

同じタグがついた質問を見る

INSERT

INSERTとは、行を追加する、コンピュータのデータベース言語SQLにおけるデータ操作言語(DML)ステートメントの1つである

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。