SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

マンガで分かるプログラミング用語辞典

「アップサート」
~マンガでプログラミング用語解説

マンガで分かるプログラミング用語辞典(251)

  • X ポスト
  • このエントリーをはてなブックマークに追加

解説

 アップサート(upsert)は、アップデート(update)とインサート(insert)を融合したデータベース用語です。既存の行があれば更新し、なければ新規に挿入する処理を指します。

 アップサートを実現する構文は、データベースの種類によって異なります。同じSQLでも、MySQLやSQLiteなどで、書き方が違います。そのため、それぞれの環境で、書き方を確かめる必要があります。

サンプル

 「アップサート」のサンプルです。

<!DOCTYPE html>
<html lang="ja">
  <head>
    <meta charset="UTF-8">
    <title>「アップサート」のサンプル</title>
    <style> #output { font-size: 32px; line-height: 1.5; white-space: pre-wrap; } </style>
  </head>
  <body>
    <pre id="output"></pre>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/sql.js/1.12.0/sql-wasm.js"></script>
    <script>
window.addEventListener('DOMContentLoaded', async e => {
    // 出力用の関数
    const print = function() {
        const el = document.querySelector('#output');
        el.textContent += [...arguments].map(x =>  `${x}`).join(', ') + '\n';
    };
    const printDB = function(title) {
        print(`----- ${title} -----`);
        res = db.exec('SELECT * FROM pet;');
        print(JSON.stringify(res[0].columns));
        res[0].values.forEach((value, i) => {
            print(i, JSON.stringify(value));
        });
    };

    // SQLite
    let res;
    const SQL = await initSqlJs({
        locateFile: file => `https://cdnjs.cloudflare.com/ajax/libs/sql.js/1.12.0/${file}`
    });
    const db = new SQL.Database();

    db.exec('CREATE TABLE pet(id INTEGER PRIMARY KEY, name TEXT NOT NULL UNIQUE, age INTEGER)');

    // インサート
    db.exec("INSERT INTO pet (name, age) VALUES ('Tama', 1)");
    db.exec("INSERT INTO pet (name, age) VALUES ('Cocoa', 2)");
    db.exec("INSERT INTO pet (name, age) VALUES ('Kuro', 3)");
    printDB('インサート');

    // アップデート
    res = db.exec("UPDATE pet SET age = 3 WHERE name = 'Cocoa'");
    res = db.exec("UPDATE pet SET age = 4 WHERE name = 'Kuro'");
    printDB('アップデート');

    // アップサート(更新)
    db.exec("INSERT INTO pet (name, age) VALUES ('Tama', 2) ON CONFLICT(name) DO UPDATE SET age = 2");
    printDB('アップサート(更新)');

    // アップサート(挿入)
    db.exec("INSERT INTO pet (name, age) VALUES ('Mike', 9) ON CONFLICT(name) DO UPDATE SET age = 9");
    printDB('アップサート(挿入)');
});
    </script>
  </body>
</html>
出力結果

----- インサート -----
["id","name","age"]
0, [1,"Tama",1]
1, [2,"Cocoa",2]
2, [3,"Kuro",3]
----- アップデート -----
["id","name","age"]
0, [1,"Tama",1]
1, [2,"Cocoa",3]
2, [3,"Kuro",4]
----- アップサート(更新) -----
["id","name","age"]
0, [1,"Tama",2]
1, [2,"Cocoa",3]
2, [3,"Kuro",4]
----- アップサート(挿入) -----
["id","name","age"]
0, [1,"Tama",2]
1, [2,"Cocoa",3]
2, [3,"Kuro",4]
3, [4,"Mike",9]

フィードバックお待ちしております!

 ご感想、解説してほしい用語、解説内容のアドバイスなどございましたら、FacebookX(旧Twitter)などでお気軽に編集部までお寄せください。よろしくお願いいたします。

この記事は参考になりましたか?

  • X ポスト
  • このエントリーをはてなブックマークに追加
マンガで分かるプログラミング用語辞典連載記事一覧

もっと読む

この記事の著者

柳井 政和(ヤナイ マサカズ)

クロノス・クラウン合同会社 代表社員http://crocro.com/オンラインソフトを多数公開。プログラムを書いたり、ゲームを作ったり、記事を執筆したり、マンガを描いたり、小説を書いたりしています。「めもりーくりーなー」でオンラインソフト大賞に入賞。最近は、小説家デビューして小説も書いています(『裏切りのプログラム』他)。面白いことなら何でもOKのさすらいの企画屋です。 

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

  • X ポスト
  • このエントリーをはてなブックマークに追加
CodeZine(コードジン)
https://codezine.jp/article/detail/20582 2025/03/25 11:00

おすすめ

アクセスランキング

アクセスランキング

イベント

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング