检索最后插入的行以与其他表关联
向多个表插入数据时,通常需要将插入的记录与另一个表关联表使用其 ID。在这种情况下,检索最后插入的行的 ID 就变得至关重要。然而,直接使用 $mysqli->insert_id 可能会导致错误的结果。
解决方案:
要正确检索最后插入的 ID,需要使用 mysqli_insert_id () 功能。此函数提供插入当前数据库连接的最后一行的 ID。下面更正后的代码演示了其用法:
<br>$stmt = $mysqli->prepare("<br> INSERT INTO table1 (username,firstname,lastname,image)<br>从 table2 t2 中选择 ?,?,?,image FROM table2 t2 WHERE username = ?<br>");<br>$stmt->bind_param('ssss', $username, $fname, $lname, $username);<br>$stmt->execute();<p>$last_id = mysqli_insert_id($conn); // 检索最后插入的 ID</p><p>// 使用检索到的 ID 更新 table1 中的 image 列<br>$stmt2 = $mysqli->prepare("<br> UPDATE table1 SET image = ? WHERE id = ?<br>");<br>$stmt2->bind_param('si', $image, $last_id);<br>$stmt2->execute();<br>
注意:确保table2中的ID字段有AUTO_INCRMENT 属性为每个插入的行生成唯一的 ID 值。
以上是如何在MySQL中可靠地检索多表关联中最后插入的行ID?的详细内容。更多信息请关注PHP中文网其他相关文章!