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 サイトの他の関連記事を参照してください。