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データベースでこれを行う方法はありますか?
mergeステートメント はあなたが望むことを達成することを可能にするはずです。私はH2の専門家ではありませんが、SQLServerでMERGE
ステートメントを数回使用しており、そのWebサイトの外観からはうまくいくはずです。
ウェブサイトから:
既存の行を更新し、存在しない行を挿入します。キー列が指定されていない場合、主キー列を使用して行が検索されます。