勉強したことのメモ

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

MySQLにて直近のクエリで発行されたAUTO_INCREMENTの値を取得する方法

   2024/05/19  MySQL データベース

やりたかったことは「MySQLで新規登録(INSERT)なら、登録時のAUTO_INCREMENTの値(id)を特定のカラム名に入れ、編集(UPDATE)なら既存の番号(id)を特定のカラム名に入れる」ということ。以下に対応方法をメモ。

 

背景

既存の番号は編集ボタンなんかを押した時にhiddenでidの値を渡せばいいが、新規登録時にMAX(id)とかで調べた際、もし削除とかが行われていた場合MAX(id)とオートインクリメントの値が異なってしまう

そういう場合はmysql_insert_id()を用いるのが良さそう。

 

リファレンス

https://www.php.net/manual/ja/function.mysql-insert-id.php

 

対応方法

<?php
if ($mode == 'insert') { //INSERTの場合
    $sql = '
        INSERT INTO table_a
            (aaa, bbb)
        VALUES
            $aaa, $bbb;
    ';
    $row = mysql_query($sql);
    $max_id = mysql_insert_id(); //ここで取得できる
}else if( $mode == 'update' ){ //UPDATEの場合
    $max_id = $id; //hiddenとかで$seqを渡しておく
}

 

注意点

mysql_insert_idはPHP5.5.0で非推奨、PHP7.0.0で削除されたため、以下のmysqli_insert_idに変更する必要あり。

https://www.php.net/manual/ja/mysqli.insert-id.php

 - MySQL データベース

  関連記事

adminerでMySQLに接続しようとするとエラーになる場合の対応方法

新しく構築したサーバにadminerを入れて接続しようとすると、「mysqlnd ...

MySQLにてdatetime型のカラムを整形し「年月日のみ形式」または「秒のみ省いた形式」で表示する方法

MySQLにてdatetime型のカラムに登録日時等を格納しており、管理画面側で ...

MySQLでテーブルのカラム名やカラムの型等、詳細情報を取得する方法

MySQLでテーブルのカラム名やカラムの型等、詳細情報を取得する方法をメモ。 & ...

MySQLでphpMyAdminやAdminer上だけ文字化けする場合の対応方法

レンタルサーバーのプログラムでWebページ上では文字化けしていないのに、phpM ...

MySQLで特定の値を加算しつつNULL値の場合は0にする方法

いくつかのコードに対して投票を行い、その合計値をスコアとして出したい。ただ、投票 ...