首頁 >資料庫 >mysql教程 >如何正確使用 mysqli_insert_id() 與外鍵關係?

如何正確使用 mysqli_insert_id() 與外鍵關係?

Linda Hamilton
Linda Hamilton原創
2024-12-30 17:15:09430瀏覽

How to Correctly Use `mysqli_insert_id()` with Foreign Key Relationships?

具有外鍵關係的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中文網其他相關文章!

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