MySQLでINSERT時にオートインクリメントではないカラムに連番を登録する方法
MySQLでINSERT時にオートインクリメントではないカラムに連番を登録したい。またデータ未登録の際は「NULL」や「0」ではなく「1」を登録したい。以下に対応方法をメモ。
データベース構造
mysql> SHOW COLUMNS FROM `test_table`; +-------+--------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-------+--------------+------+-----+---------+----------------+ | id | int | NO | PRI | NULL | auto_increment | | name | varchar(255) | NO | | NULL | | | order | int | NO | | NULL | | +-------+--------------+------+-----+---------+----------------+
orderカラムに対して連番を登録したい。
対応方法
ソースコード
INSERT INTO `test_table`
(`order`, `name`)
SELECT COALESCE(MAX(`order`) + 1, 1), "鈴木"
FROM `test_table`;
注意点
データベース構造からすると「name」→「order」の順で書きたいところだけど、そうするとシンタックスエラー(MySQL 1064エラー)になる。そのため「order」を頭に持ってくること。
リファレンス
COALESCE
https://dev.mysql.com/doc/refman/8.0/ja/comparison-operators.html#function_coalesce
MAX
https://dev.mysql.com/doc/refman/8.0/ja/aggregate-functions.html#function_max
関連記事
-
-
MySQLでIPアドレスを数値として入れると変な値になる場合の対処方法
MySQLでIPアドレスをINET_ATON関数を用いてINT型に変換し格納する ...
-
-
PHP / MySQLで2038年問題の対策
先日打ち合わせの際に「タイムスタンプを使ってユニークキーに云々~~」といったよう ...
-
-
MySQLで1対多というテーブル構造でデータ結合と条件検索する方法
MySQLで飲食店舗テーブルと休業日テーブルがあり、1店舗に対して複数行の休業日 ...
-
-
MySQLにてUUIDを発行しプライマリキー(主キー)にする方法
普段MySQLでプライマリキー(主キー)を使う場合、オートインクリメントを利用し ...
-
-
MySQLでストアドプロシージャ戻り値対応版であるストアドファンクションの設定と利用方法
先日MySQLのストアドプロシージャに関するメモを書いたが、今回はストアドファン ...