HEXA BLOG
ヘキサブログ
プログラム
初期化も更新もまとめて
朝夕が冷えてきましたね。
タイラです。
さて前回、前々回に引き続き今回もデータベースのお話で、ちょっと便利な
INSERT … ON DUPLICATE KEY UPDATE構文
をご紹介したいと思います。
例として 実行する都度値をインクリメントするような処理 を作ります。
次の順で行うクエリを作ると以下のようになります。
1. 初期化(更新分もついでに行う)
2. 値更新
■テーブル構造 sampleテーブル +------------+-----------+------+-----+-------------------+-------+ | Field | Type | Null | Key | Default | Extra | +------------+-----------+------+-----+-------------------+-------+ | id | int(11) | NO | PRI | NULL | | | count | int(11) | NO | | NULL | | | created_at | datetime | NO | | NULL | | | updated_at | timestamp | NO | | CURRENT_TIMESTAMP | | +------------+-----------+------+-----+-------------------+-------+ ■1. 初期化クエリ INSERT INTO `sample` (id, count, created_at, updated_at) VALUES ('1', '1', NOW(), NOW()); ■2. 値更新クエリ UPDATE `sample` SET count = count + 1 WHERE id = 1;
実行する際に正しく順序が守られている場合はよいのですが、
・初期化クエリを2回以上実行する
・初期化クエリを実行せず、更新クエリを実行する
という事が発生した際に正しい結果が得られません。
それらの問題を解消するクエリがこちら
INSERT INTO `sample` (id, count, created_at, updated_at) VALUES ('1', '1', NOW(), NOW()) ON DUPLICATE KEY UPDATE count = count + 1;
INSERT構文とUPDATE構文を合わせた
INSERT … ON DUPLICATE KEY UPDATE構文になります。
簡単な挙動としては
INSERTが実行される前に KEY(=プライマリキー) が重複を確認し
重複がない場合は INSERT が、
重複がある場合は UPDATE が行われます。
初期化クエリ、値更新クエリを置き換えると以下のようになります。
■1. 初期化クエリ INSERT INTO `sample` (id, count, created_at, updated_at) VALUES ('1', '1', NOW(), NOW()) ON DUPLICATE KEY UPDATE count = count + 1; ■2. 値更新クエリ INSERT INTO `sample` (id, count, created_at, updated_at) VALUES ('1', '1', NOW(), NOW()) ON DUPLICATE KEY UPDATE count = count + 1; ■結果表示 SELECT * FROM `sample`; +----+-------+---------------------+---------------------+ | id | count | created_at | updated_at | +----+-------+---------------------+---------------------+ | 1 | 2 | 2013-09-30 18:00:00 | 2013-09-30 18:00:00 | +----+-------+---------------------+---------------------+
同じクエリで初期化も更新も出来ました。
今回はcountのインクリメントだけを行っていますが、
UPDATE構文で取り扱える内容は基本的にこの構文でも扱えます。
ではー
CATEGORY
- about ヘキサ (166)
- 部活動 (6)
- CG (18)
- プロジェクトマネジメント (1)
- 研修 (5)
- 美学 (1)
- いいモノづくり道 (230)
- 採用 -お役立ち情報も- (149)
- プログラム (188)
- デザイン (99)
- ゲーム (274)
- 日記 (1,104)
- 書籍紹介 (113)
- その他 (875)
- 就活アドバイス (20)
- ラーメン (3)
- ライフハック (25)
- イベント紹介 (10)
- 料理 (23)
- TIPS (7)
- 怖い話 (3)
- サウンド (5)
- 子育て (1)
- 筋トレ (1)
- 商品紹介 (21)
- アプリ紹介 (31)
- ソフトウェア紹介 (33)
- ガジェット紹介 (12)
- サイト紹介 (10)
- 研究・開発 (34)
- 回路図 (4)
- アナログゲーム (40)
- 交流会 (21)
- 報告会 (3)
- インフラ (25)
- グリとブラン (6)
- カメラ (9)
- クラフト (27)
- 部活 (14)
- 画伯 (15)
- カレー (6)
- 音楽(洋楽) (6)
- 映画・舞台鑑賞 (43)
- 飼育 (5)
- いぬ (8)
- ねこ (19)
ARCHIVE
- 2024年
- 2023年
- 2022年
- 2021年
- 2020年
- 2019年
- 2018年
- 2017年
- 2016年
- 2015年
- 2014年
- 2013年
- 2012年
- 2011年
- 2010年
- 2009年
- 2008年
- 2007年