複数テーブルの挿入のために 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 サイトの他の関連記事を参照してください。