MySQLにて直近のクエリで発行されたAUTO_INCREMENTの値を取得する方法
2024/05/19
やりたかったことは「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に変更する必要あり。
関連記事
-
-
MySQLで「doesn't have a default value」エラーの対処
MySQLでINSERT時に「Field 'カラム名' doesn't have ...
-
-
MySQLでIPを整数値としてカラムに格納する
MySQLでIPを整数値としてカラムに格納しているケースがあった。今までIPが必 ...
-
-
MySQLで全角半角を区別せずに検索する方法(collate utf8_unicode_ci)
あるシステムでMySQLの検索時に「WHERE test_column coll ...
-
-
MySQLのview(ビュー)で仮想的なテーブルを作成する方法
MySQL関連のサイトを見ているとview(ビュー)が云々という記事を見かけた。 ...
-
-
PHPからMySQLにシリアライズしたデータを格納
アンケートフォームみたいなのがあって、 今後も定期開催し、尚且つ質問内容は増減す ...