MySQLで直近に挿入したオートインクリメントの値と次回挿入する値を取得する方法
2024/04/17
phpとmysqliを使っている中で次回挿入するオートインクリメントの値と、前回挿入したオートインクリメントの値を取得したかった。
前回分は以前からたまに使ってたので良いんだけど、次回挿入する値のところで、max(hoge) + 1みたいな形で取得を考えたけど、行の削除が発生すると+1にならないケースがある。なので以下で対応する。
ソースコード
次回挿入する値を取得
//次回挿入する値を取得
$query = '
SHOW TABLE STATUS
LIKE "table"
';
$row = $mysqli->query($query);
if( $row->num_rows == 0 ){ //行が見当たらない場合は1を入れる
$count = 1;
} else {
while ($rs = $row->fetch_array(MYSQLI_ASSOC)) {
$count = $rs['Auto_increment']; //見当たる場合はその値を入れる
}
}
直近で挿入した値を取得
//直近で挿入した値を取得
$query = '
INSERT INTO table
(aaa, bbb)
VALUES
(aaa, bbb)
';
$row = $mysqli->query($query);
$count = $mysqli->insert_id; //ここに直近で挿入したオートインクリメント値が入る
関連記事
-
-
MySQLのTEMPORARY TABLE(テンポラリテーブル)で高速化を図る方法
MySQLで5000万件ぐらいデータが入っているテーブルから日本語検索しないとい ...
-
-
PHP / MySQLで2038年問題の対策
先日打ち合わせの際に「タイムスタンプを使ってユニークキーに云々~~」といったよう ...
-
-
MySQLで直近〇日、〇ヶ月、〇年以内のデータを検索する方法
他社が作成されたSQL文を見ているとDATE_ADDという使ったことの無い関数が ...
-
-
MySQLが起動も再起動もできない際の対応方法
サイトで障害が発生した。FTPやSSH接続は出来るけどサイト自体は表示されない。 ...
-
-
MySQLで月別に集計を行う。あと日付時刻関数。
現在進行形でやっているデータ集計系だけど 新たな発見があったのでメモ。 ■日付時 ...