web-dev-qa-db-ja.com

存在しない場合はh2テーブルに挿入します

H2を使用しています。値が存在しない場合は、テーブルに値を挿入したいと思います。次のコマンドでテーブルを作成します。

CREATE TABLE IF NOT EXISTS $types 
  (type VARCHAR(15) NOT NULL UNIQUE);

そして、私は次のようなことをしたい

REPLACE INTO types (type) values ('type1');

見つけた しかし、h2コンソールからこれを実行するとエラーが発生します。

Syntax error in SQL statement "REPLACE[*] INTO TYPES (TYPE) VALUES ('expense') "; expected "ROLLBACK, REVOKE, RUNSCRIPT, RELEASE, {"; SQL statement:
REPLACE INTO types (type) values ('expense') [42001-170] 42001/42001

私も試しました

INSERT IGNORE INTO types (type) values ('expense');

そして

INSERT INTO types (type) values ('expense') ON DUPLICATE KEY UPDATE type=type;

新しい挿入が古いデータを上書きするのか、それとも新しい挿入を実行しないだけなのかは関係ありません。 h2データベースでこれを行う方法はありますか?

15
Alison

mergeステートメント はあなたが望むことを達成することを可能にするはずです。私はH2の専門家ではありませんが、SQLServerでMERGEステートメントを数回使用しており、そのWebサイトの外観からはうまくいくはずです。

ウェブサイトから:

既存の行を更新し、存在しない行を挿入します。キー列が指定されていない場合、主キー列を使用して行が検索されます。

21
JodyT