我正在撰写有博文的博客。 我想插入3个表
帖子,类别和Post_categories(显示帖子的正确类别)
我使用mysqli尝试了所有内容,例如:
$titel = $_POST['titel'];
$post = $_POST['post-text'];
$sql=
"INSERT INTO posts (titel, post)
VALUES ('$titel', '$post')
INSERT INTO post_categories (idposts)
VALUES ('". $mysqli->insert_id() ."')
";
if (!mysqli_query($link,$sql))
{
die('Error: ' . mysqli_error($link));
}
echo "1 record added";
mysqli_close($link);
但是这没用。我现在被困了两个小时,我几乎放弃了。 我真的不知道如何在Mysqli中这样做。我知道它在Mysql中是如何工作的。
希望有人可以帮我解决这个问题。
我的表格结构如下:
帖子
idposts
Titel的
发布
加入
类别
idcategories
类
post_categories
ID
idposts
idcategories
答案 0 :(得分:0)
你不能使用mysqli_query同时执行两个查询,如果你真的想这样做,你应该使用mysqli_multi_query
答案 1 :(得分:0)
由于您要插入多个表,请尝试使用事务。此外,在查询执行之前,您无法获取mysql_insert_id()。
mysqli_autocommit($link, FALSE);
$sql = "INSERT INTO posts (titel, post) VALUES ('".$titel."', '".$post."')";
if (mysqli_query($link, $sql ) === TRUE) {
$postId = mysqli_insert_id($link);
$sql1 = "INSERT INTO post_categories (idposts) VALUES ('".$postId."')";
mysqli_query($link, $sql1 );
}
if (!mysqli_commit($link)) { //commit transaction
print("Table saving failed");
exit();
}