勉強したことのメモ

Webエンジニア / プログラマが勉強したことのメモ。

MySQLでINSERT時にオートインクリメントではないカラムに連番を登録する方法

  MySQL データベース

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 データベース

  関連記事

InnoDBのオートインクリメントで抜け番が発生する原因について

MySQLのInnoDBでIDというカラムにオートインクリメント設定していたが、 ...

MySQLでカラム数の異なるテーブルを結合する(UNION)

MySQLでカラム数の異なるテーブル同士をUNIONで結合させたかった。ただ、何 ...

MySQLでdatetime型データの〇日後を取得する方法(DATEDIFF)

MySQLでdatetime型データがあり、何日経過しているかを取得し、〇日経過 ...

MySQLにて指定したカラムがNULLもしくは空の場合、あらかじめ決めておいた内容で表示する方法

何らかのフォームとMySQLを組み合わせた際に任意入力の項目はそのカラムがNUL ...

MySQLでJOINの高速化

JOINで無茶苦茶悩んだのでメモ。やりたかった事は、MySQLで テーブルAには ...