將新行插入 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中文網其他相關文章!