0

記事、タグ、articles_tagsの3つのテーブルを持つMySQLデータベースがあります

それぞれのスキーマは次のとおりです。

記事: id-articletitle-articleorganization-articledate-articleurl

タグ: id-tag_contents

articles_tags: id-article_id-tag_id

また、2つのPHPフォームがあります:addnew.phpとedit.php

この質問は特にaddnew.phpに関するものですが、edit.phpにも関連しています。

addnew.phpのフォームは、その名前が示すとおりに機能し、データベースに新しいエントリを作成します。現在、いくつかのテキスト入力フィールドと2つのチェックボックスを使用しています。したがって、たとえば、記事のタイトル、作成者、URL、およびアクセス日を記事テーブルに挿入すると同時に、タグをタグテーブルに挿入することもできます(チェックボックスのいずれかまたは両方をチェックすることにより)。私が理解できないのは、これらのテーブルを3番目のテーブルと交差させる方法です。オンラインで調べましたが、必要なものが見つからないようです。

参考までに、addnew.phpのコードは次のとおりです。

    <?php
     function renderForm($articletitle, $articleorganization, $articledate, $articleurl, $articletags )
     {
     ?>
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    . . .
    </head>

    <body>

    <div class="container">
      <div class="header">
      . . .
      </div>
        <div class="sidebar1">
        . . .
        </div>
      <div class="content">
            <div id="stylized" class="myform">
          <form id="form" name="form" action="" method="post">
            <h1>Create a new entry in the database</h1>
            <table width="100%" border="0" cellpadding="6">
              <tr>
                <td colspan="2"><legend>Article details</legend></td>
              </tr>
              <tr>
                <td width="20%" align="right"><span class="field">Article Title:</span></td>
                <td width="80%" align="left"><span class="field">
                  <input name="articletitle" type="text" value="<?php echo $articletitle; ?>" size="50"/>
                </span></td>
              </tr>
              <tr>
                <td align="right"><span class="field">Article Author:</span></td>
                <td align="left"><span class="field">
                  <input name="articleorganization" type="text" value="<?php echo $articleorganization; ?>" size="50"/>
                </span></td>
              </tr>
              <tr>
                <td align="right"><span class="field">Access Date:</span></td>
                <td align="left"><span class="field">
                  <input name="articledate" type="text" value="MM/DD/YYYY" size="50"/>
                </span></td>
              </tr>
              <tr>
                <td align="right"><span class="field">Article URL:</span></td>
                <td align="left"><span class="field">
                <input name="articleurl" type="text" value="<?php echo $articleurl; ?>" size="50"/>
                </span></td>
              </tr>
              <tr>
                <td align="right"><span class="field">Article Tags:</span></td>
                <td align="left"><span class="field">
                        <input type="checkbox" name="articletags[]" value="geology" id="articletags_0" />
                        <input type="checkbox" name="articletags[]" value="astronomy" id="articletags_1" />
                </span></td>
              </tr>
            </table>
            <footer><input type="submit" name="submit" value="Add this Article"></footer>
            </form>
        </div>
      <div class="footer">
       . . .
       </div>
    </body>
    </html>
    <?php 
     }

     include('settings.php');

     if(count($articletags) > 0)
    {
     $articletags_string = implode(",", $articletags);
    }

     if($_SERVER['REQUEST_METHOD'] == 'POST')
     { 

     $articletitle = mysql_real_escape_string(htmlspecialchars($_POST['articletitle']));
     $articleorganization = mysql_real_escape_string(htmlspecialchars($_POST['articleorganization']));
     $articledate = mysql_real_escape_string(htmlspecialchars($_POST['articledate']));
     $articleurl = mysql_real_escape_string(htmlspecialchars($_POST['articleurl']));
     $articletags = implode(',', $_POST['articletags']);


     if ($articletitle == '' || $articleorganization == '')
     {

     $error = 'ERROR: Please fill in all required fields!';


     renderForm($articletitle, $articleorganization);
     }
      else
     {

     mysql_query("INSERT INTO articles SET articletitle='$articletitle', articleorganization='$articleorganization', articledate='$articledate', articleurl='$articleurl' ");
     mysql_query("INSERT INTO articles_tags SET articletags='$articletags' ")


     or die(mysql_error()); 


     header("Location:addsuccess.php"); 
     }
     }
     else

     {
      renderForm('','','','','');
     }
    ?>
4

3 に答える 3

3

mysql_insert_id を使用して、クエリの最後の挿入 ID を取得できます。

mysql_query("INSERT INTO articles SET articletitle='$articletitle', articleorganization='$articleorganization', articledate='$articledate', articleurl='$articleurl' ");
$article_id = mysql_insert_id();
mysql_query("INSERT INTO tags SET articletags='$articletags' ");
$tag_id = mysql_insert_id();
于 2012-06-19T08:11:13.160 に答える
1

最後のステートメントmysql_insert_idの ID を取得するために使用します。INSERT

http://php.net/manual/en/function.mysql-insert-id.php

于 2012-06-19T08:10:38.893 に答える
1

誰かがこれに遭遇し、mysql ではなく PDO を使用している場合に備えて、PDO でそれを行う方法は次のとおりです。

$article_id = $pdo->lastInsertId();

「$pdo」をデータベース変数に変更します。

于 2015-05-21T22:26:56.353 に答える