ホームページ >データベース >mysql チュートリアル >複数テーブルの挿入後に MySQL で最後に挿入された ID を取得する方法

複数テーブルの挿入後に MySQL で最後に挿入された ID を取得する方法

Patricia Arquette
Patricia Arquetteオリジナル
2024-12-10 14:24:12927ブラウズ

How to Retrieve the Last Inserted ID in MySQL After Multi-Table Inserts?

複数テーブルの挿入のために MySQL で最後に挿入された ID を取得する

複数のデータベース テーブルを操作する場合、多くの場合、最後に挿入された ID を取得する必要があります。複数のテーブルに挿入した後の ID。一般的なシナリオの 1 つは、後続の挿入が他のテーブルに行われた場合でも、最初のテーブルから最後に挿入された ID を取得することです。

次の SQL クエリを考えてみましょう。

INSERT INTO table1 (title,userid) VALUES ('test',1);
INSERT INTO table2 (parentid,otherid,userid) VALUES (LAST_INSERT_ID(), 4, 1);
SELECT LAST_INSERT_ID();

デフォルトでは、LAST_INSERT_ID( ) は、最後に挿入されたテーブルの最後に挿入された ID (この場合は table2) を返します。 table1 から最後に挿入された ID を取得するには、いくつかの方法があります。

最後に挿入された ID を変数に保存する:

table1 に値を挿入して保存する変数に最後に挿入された ID:

SET @last_id_in_table1 = LAST_INSERT_ID();

その後の他のテーブルへの挿入はこれに影響しません

最大 ID の取得:

別のアプローチは、挿入後に table1 から最大 ID を見つけることです。が作成されました:

SELECT MAX(id) FROM table1;

これは、他のテーブルが挿入されている場合でも、最後に挿入された ID を返します。

注: 最大 ID を取得するときは、潜在的な競合状態を考慮することが重要です。別のプロセスまたは接続が table1 に同時に値を挿入した場合、取得される最大 ID は最後に挿入された値を正確に反映しない可能性があります。

以上が複数テーブルの挿入後に MySQL で最後に挿入された ID を取得する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。