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);

しかし、これはうまくいきませんでした。私は今2時間立ち往生しています、そして私はこれをほとんどあきらめています. Mysqliでこれを行う方法が本当にわかりません。Mysqlでどのように機能するかは知っていました。

誰かがこれで私を助けてくれることを願っています。

私のテーブル構造は次のようになります。

投稿

idposts
タイトル
の投稿
が追加されました

カテゴリー

idcategories
カテゴリ

post_categories

id
idposts
idcategories

4

2 に答える 2

0

mysqli_query を使用して 2 つのクエリを同時に実行することはできません。実際に実行したい場合は、代わりに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 に答える