首頁 >資料庫 >mysql教程 >如何在單一 MySQL 查詢中檢索插入的行值?

如何在單一 MySQL 查詢中檢索插入的行值?

DDD
DDD原創
2024-10-25 08:05:281060瀏覽

How to Retrieve Inserted Row Values in a Single MySQL Query?

在單一 MySQL 查詢中擷取插入的行值

將新行插入 MySQL 表時,通常需要擷取新插入的值以進行進一步處理或參考。以下是如何在單一查詢中插入一行並同時取得其內容。

提供的查詢:

INSERT INTO `items` (`item`, `number`, `state`) 
(SELECT '3', `number`, `state` FROM `item_bug` WHERE `id`='3')

將一行插入到 items 表中,從 item_bug 表中選擇資料id 等於 3。但是,此查詢不提供檢索新插入記錄的方法。

要在單一查詢中同時實作插入和檢索,可以使用 LAST_INSERT_ID() 函數。此函數傳回最後插入的行的 ID。透過將其與附加查詢結合,您可以獲得插入記錄的詳細資訊。

這是修改後的查詢:

INSERT INTO `items` (`item`, `number`, `state`) 
(SELECT '3', `number`, `state` FROM `item_bug` WHERE `id`='3');

SELECT * FROM `items` WHERE `id` = LAST_INSERT_ID();

此查詢首先將行插入到 items 表中。然後,它執行 SELECT 查詢,該查詢從 items 表中取得 id 等於最後插入的 ID 的行的所有列。

以上是如何在單一 MySQL 查詢中檢索插入的行值?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn