php/mysql:将外键表中的值插入表1

rwqw0loc  于 2021-06-24  发布在  Mysql
关注(0)|答案(3)|浏览(340)

我正在为一个类开发一个桌面rpg怪物数据库,我需要用以下参数将值插入我的怪物表:怪物表。

CREATE TABLE Monsters (
ID int NOT NULL AUTO_INCREMENT,
Name varchar(100) NOT NULL,
HP int unsigned NOT NULL,
MP int unsigned NOT NULL,
AC int unsigned NOT NULL,
MonsterType_ID int NOT NULL,
PRIMARY KEY(ID),
FOREIGN KEY(MonsterType_ID) REFERENCES MonsterType(ID) ON DELETE CASCADE
) ENGINE=InnoDB;

我还有一张怪物型的table

CREATE TABLE MonsterType (  
ID int NOT NULL AUTO_INCREMENT,  
Name varchar(100) NOT NULL,  
PRIMARY KEY (ID)  
) ENGINE=InnoDB;

我已经设置了php代码:php monster query

if (isset($_POST["submit"])) {
    if( (isset($_POST["Name"]) && $_POST["Name"] !== "") && 
    (isset($_POST["HP"]) && $_POST["HP"] !== "") &&
    (isset($_POST["MP"]) && $_POST["MP"] !== "") &&
    (isset($_POST["AC"]) && $_POST["AC"] !== "") &&
    (isset($_POST["MonsterType_ID"]) && $_POST["MonsterType_ID"] !== "") ) {

            $query = "INSERT INTO Monsters ";
            $query .= "(Name, HP, MP, AC, MonsterType_ID) ";
            $query .= "VALUES (";
            $query .= "'".$_POST["Name"]."',";
            $query .= "'".$_POST["HP"]."',";
            $query .= "'".$_POST["MP"]."',";
            $query .= "'".$_POST["AC"]."',";
            $query .= "'".$_POST["MonsterType_ID"]."');";

            $result = $mysqli->query($query);

当我去添加怪物时,怪物类型字段只接受对应于monstertype.id索引的整数值。相反,我希望能够在文本字段中键入类型名称

INSERT INTO MonsterType (Name)
VALUES
    ('Abberation'),
    ('Beast'),
    ('Celestial'),
    ('Construct'),
    ('Dragon'),
    ('Elemental'),
    ('Fey'),
    ('Fiend'),
    ('Giant'),
    ('Humanoid'),
    ('Monstrosity'),
    ('Ooze'),
    ('Plant'),
    ('Undead');

并将相应类型名的id插入数据库。
我已经可以使用以下查询显示与怪物关联的怪物类型:monster display

$query = "SELECT Monsters.ID AS `mID`, 
          Monsters.Name AS `MName`, Monsters.MonsterType_ID, 
          MonsterType.Name FROM Monsters ";
$query .= "inner join MonsterType ON Monsters.MonsterType_ID = MonsterType.ID 
          ORDER BY MonsterType.Name ASC";
$result = $mysqli->query($query);

if ($result && $result->num_rows > 0) {
    echo "<div class='row'>";
    echo "<center>";
    echo "<h2>The Monster Database</h2>";
    echo "<table>";
    echo "<tr><th>Name</th><th>Type</th>
    <th></th><th></th></tr>";
    while ($row = $result->fetch_assoc())  {
        echo "<tr>";    
        //Output FirstName and LastName
        echo "<td>" .$row["MName"]."</td>";
        echo "<td>" .$row["Name"]."</td>";

我只是不知道如何更改我的insert查询,以便它在文本字段中接受monstertype.name,并在insert into monsters表查询中使用与该monstertype.name关联的monstertype.id。
当然,理想情况下,我只希望我的monster type字段是所有monstertype.names的下拉列表,但我在使用嵌入在php块中的html代码创建下拉字段时遇到了问题。

echo '
    <div class="row">
    <label for="left-label" class="left inline">

    <h2>Add a monster</h2>
    <form method="POST" action="addMonsters.php">

    <p> Monster Name: <input type="text" name="Name">
    <p> Hit Points: <input type="text" name="HP">
    <p> Mana Points: <input type="text" name="MP">
    <p> Armor Class: <input type="text" name="AC">
    <p> Monster Type: <input type="text" name="MonsterType_ID">
    /////// This didn't work
    <p>Monster Type: <select name="Name">
    <option></option>
    <?php
         $query = "SELECT DISTINCT Name FROM MonsterType";
         $result = $mysqli->query($query);
         if($result && $result->num_rows>=1){
            while($row = $result->fetch_assoc()){
               echo "<option value = '".$row['Name']."'>".$row['Name']."/option>";
        }
    }
         else {echo "<h2>No query results</h2>";}
     ?>
     </select>
      ///////////   
    <input type="submit" name="submit" class="button tiny round" value="Add monster" />
    </form>
    ';

如果有人能解决这个问题,那就更好了。
任何指导都将不胜感激!谢谢您!
编辑:
我已使用以下代码块成功填充下拉列表:

echo '<p>Monster Type: <select name="MonsterType_ID">';
        echo '<option></option>';

                $query = "SELECT DISTINCT ID, Name FROM MonsterType";
                $result = $mysqli ->query($query);
                if($result && $result->num_rows>=1){
                    while($row2 = $result->fetch_assoc()){
                        if($row2['mID'] == $MonsterID){
                            echo "<option selected value = '".$row2['ID']."'>".$row2['Name']."</option>";
                        }
                        else{
                            echo "<option value = '".$row2['ID']."'>".$row2['Name']."</option>";
                        }
                    }
                }

                else {
                    echo "<h2>No query results</h2>";
                }
        echo '</select></p>';

但是,这并不能正确地发布到原始查询,并且我得到一条错误消息,即我没有填写所有信息(我丢失了一个引号(select name=“monstertype\u id”))但是,我仍然得到“error!无法添加“$\u post[“name”]。”!“;所以这意味着查询的结果是假的。不确定会发生什么,除了可能monstertype.id与monsters.monstertype\u id不匹配。

if (isset($_POST["submit"])) {
    if( (isset($_POST["Name"]) && $_POST["Name"] !== "") && 
    (isset($_POST["HP"]) && $_POST["HP"] !== "") &&
    (isset($_POST["MP"]) && $_POST["MP"] !== "") &&
    (isset($_POST["AC"]) && $_POST["AC"] !== "") &&
    (isset($_POST["MonsterType_ID"]) && $_POST["MonsterType_ID"] !== "")     ) {

            //STEP 2.
                //Create query to insert information that has been posted
            $query = "INSERT INTO Monsters ";
            $query .= "(Name, HP, MP, AC, MonsterType_ID) ";
            $query .= "VALUES (";
            $query .= "'".$_POST["Name"]."',";
            $query .= "'".$_POST["HP"]."',";
            $query .= "'".$_POST["MP"]."',";
            $query .= "'".$_POST["AC"]."',";
            $query .= "'".$_POST["MonsterType_ID"]."'));";
            //$query .= "(SELECT ID FROM MonsterType WHERE Name='".$_POST["MonsterType_ID"]."'));";

            $result = $mysqli->query($query);

            // Execute query

        if($result) {

        $_SESSION["message"] = $_POST["Name"]." has been added!";
            header("Location: readMonsters.php");
            exit;

        }
        else {

        $_SESSION["message"] = "Error! Could not add ".$_POST["Name"]."!";
            header("Location: addMonsters.php");
            exit;
        }
    }
    else {
        $_SESSION["message"] = "Unable to add monster. Fill in all information!";
        header("Location: addMonsters.php");
        exit;
    }

编辑2:一切正常!下拉列表是正确的,我只需要更改查询以接受正确的参数。

$query = "INSERT INTO Monsters ";
            $query .= "(Name, HP, MP, AC, MonsterType_ID) ";
            $query .= "VALUES (";
            $query .= "'".$_POST["Name"]."',";
            $query .= "'".$_POST["HP"]."',";
            $query .= "'".$_POST["MP"]."',";
            $query .= "'".$_POST["AC"]."',";
            //$query .= "'".$_POST["MonsterType_ID"]."'));";
            $query .= "(SELECT ID FROM MonsterType WHERE ID='".$_POST["MonsterType_ID"]."'));";

            $result = $mysqli->query($query);

即,我将(select id from monstertype where name=…)更改为(select id from monstertype where id=…)。我的下拉列表现在成功运行。谢谢尼克的帮助!

kdfy810k

kdfy810k1#

您需要查询monstertype表,根据monstertype名称获取id,并使用检索到的monstertype id构成insert查询的一部分。
因此,解决方案是要么将其拆分为两个查询,要么使用insert select(insert with subquery)。如果将其拆分为两个查询,则必须先选择,然后插入。如果要在一个查询中执行此操作,可以使用insert select

ryevplcw

ryevplcw2#

执行插入操作时,可以使用select。

INSERT INTO monsters (your, variable, fields, here, monsterTypeID) 
Select 'varname', 'varname', 'varname', 'varname', monsterTypeID FROM
MonsterTypeNames WHERE name='namevar';
2w3rbyxf

2w3rbyxf3#

简而言之,根据您当前的代码结构,更改此行:

$query .= "'".$_POST["MonsterType_ID"]."');";

$query .= "(SELECT ID FROM MonsterType WHERE Name='".$_POST["MonsterType_ID"]."'));";

这将执行一个子查询select,从monstertype中为提交的名称获取适当的id。
冗长的回答
这种方法的问题是,如果用户在monstertype\u id文本框中键入的内容不是有效的monstertype(例如,他们将“abberation”误键入“abberation”,则此查询将失败。您尝试生成下拉列表是正确的方法。你会想要这样的东西:

<p>Monster Type: <select name="MonsterType_ID">
<?php
     $query = "SELECT ID, Name FROM MonsterType";
     $result = $mysqli->query($query);
     if ($result) { 
        while ($row = $result->fetch_assoc()) {
           echo "<option value = \"" . $row['ID'] . "\">" . $row['Name'] . "</option>";
        }
     }
 ?>
 </select>

这将为您提供一个选择选项值的位置(这是在中传递给php的内容) $_POST )是你需要插入怪物数据库的id。这样,您就不需要像简短答案中描述的那样进行任何预处理(基本上您现有的代码将按原样工作)。

相关问题