1

我正在写一个有帖子的博客。我想插入 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
标题
帖子已
添加

类别

idcategories
类别

post_categories

id
idposts
idcategories

4

2 回答 2

0

你不能使用 mysqli_query 同时执行两个查询,如果你真的想这样做,你应该使用mysqli_multi_query

于 2014-01-19T14:15:29.470 回答
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();
}
于 2014-01-19T14:16:21.747 回答