ホームページ >データベース >mysql チュートリアル >ON DUPLICATE KEYを使用したMySQL INSERT/UPDATE後に行IDを取得するにはどうすればよいですか?

ON DUPLICATE KEYを使用したMySQL INSERT/UPDATE後に行IDを取得するにはどうすればよいですか?

Barbara Streisand
Barbara Streisandオリジナル
2024-12-05 08:51:13568ブラウズ

How to Get the Row ID After a MySQL INSERT/UPDATE with ON DUPLICATE KEY?

MySQL ON DUPLICATE KEY を使用して INSERT/UPDATE 後に行の ID を取得する方法

ON DUPLICATE KEY を使用したデータの挿入または更新MySQL の句は、重複キー エラーを処理する便利な方法です。ただし、操作後に影響を受ける行の ID を取得するのは困難な場合があります。

一般的な前提の 1 つは、LAST_INSERT_ID() 関数は新しく挿入された行の ID のみを返すということです。ただし、ON DUPLICATE KEY シナリオでは、行が変更された場合に更新された ID が返される場合もあります。

解決策: LAST_INSERT_ID(expr)

LAST_INSERT_ID を作成するには() は挿入と更新の両方に意味があり、MySQL では次のものが提供されます。回避策:

INSERT INTO table (a,b,c) VALUES (1,2,3)
ON DUPLICATE KEY UPDATE>

この例では、id 列が AUTO_INCREMENT 主キーであると想定されます。更新時に LAST_INSERT_ID(id) を id 列に割り当てることで、関数は更新された ID を返します。

最後の挿入/更新 ID を取得する

回避策が適用されたらLAST_INSERT_ID() 関数を使用して、挿入された行の ID を取得するか、 updated:


このアプローチを使用すると、別のクエリを実行してフェッチすることなく、INSERT/UPDATE 操作の影響を受ける行の ID を取得できます。

以上がON DUPLICATE KEYを使用したMySQL INSERT/UPDATE後に行IDを取得するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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