具有外鍵關係的mysqli_insert_id
在處理涉及外鍵關係的多個表時,正確關聯它們之間的資料非常重要。本文解決了從一個表 (table2) 檢索最後插入的 ID 並使用它向另一個表 (table1) 插入一行的問題。
問題:
程式碼嘗試使用 $image = $mysqli->insert_id 將 table2 中最後插入的 ID 綁定到 table1 中的映像列。但是,這種方法會失敗,導致表之間無法正確關聯。
解決方案:
要解決此問題,第一步是確保 table2 中的 ID 欄位被定義為自增欄位。接下來,使用 mysqli_insert_id() 從 table2 中檢索最後插入的 ID。以下是修改後的程式碼:
$last_id = mysqli_insert_id($mysqli); // Get last inserted ID from table2 $stmt = $mysqli->prepare(" INSERT INTO table1 (username, firstname, lastname, image) SELECT ?,?,?,image FROM table2 t2 WHERE username = ? AND t2.id = ? "); $stmt->bind_param('sssss', $username, $fname, $lname, $username, $last_id); $stmt->execute();
mysqli_insert_id() 函數從 table2 擷取最後插入的 ID,並使用 $last_id 將其綁定到 table1 中的影像列。這可以確保圖像與 table1 中的名字、姓氏和使用者名稱正確關聯,從而保留兩個表之間的外鍵關係。
以上是如何正確使用 mysqli_insert_id() 與外鍵關係?的詳細內容。更多資訊請關注PHP中文網其他相關文章!