php – 如何使用多个表而不是获取重复数据? (MySQL的/ PDO)

前端之家收集整理的这篇文章主要介绍了php – 如何使用多个表而不是获取重复数据? (MySQL的/ PDO)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在努力创建一个可容纳大约1000支枪的火器站点.这不是很多数据库条目,但我试图尽可能保持数据库的轻量级.我已经创建了五个表,记住了规范化,并且在将数据放入一个查询中的所有五个表时遇到了问题.我的数据库结构如下:
+-----------------+ +-----------------+ +-----------------+ +-----------------+ 
|       make      + |      model      | |      image      | |      type       |
+-----------------+ +-----------------+ +-----------------+ +-----------------+
| PK | make_id    | | PK | model_id   | | PK | model_id   | | PK | type_id    |
+-----------------+ +-----------------+ +-----------------+ +-----------------+
|    | make_name  | |    | make_id    | |    | image_path | |    | type_name  |
+-----------------+ +-----------------+ +-----------------+ +-----------------+  
                    |    | type_id    |
                    +-----------------+           +------------------+
                    |    | caliber_id |           |      caliber     |
                    +-----------------+           +------------------+
                    |    | model_name |           | PK | caliber_id  |
                    +-----------------+           +------------------+ 
                    |    | cost       |           |    | caliber_name|
                    +-----------------+           +------------------+
                    |    | description|
                    +-----------------+

这可能是TOO规范化,但这是我正在使用的;)

让我展示代码

形成

<form action="post" method="addProduct.PHP" enctype="multipart/form-data">
    make:    <input type="text" name="make" />
    model:   <input type="text" name="model" />
    type:    <input type="text" name="type" />
    caliber: <input type="text" name="caliber" />
    cost:    <input type="text" name="cost" />
    desc.:   <input type="text" name="description" />  
    Image:   <input type="file" name="image" id="image" />
             <input type="submit" name="submit" value="Add Item" />
</form>

addProduct.PHP

$make        = $_POST['make'];
$model       = $_POST['model'];
$type        = $_POST['type'];
$caliber     = $_POST['caliber'];
$cost        = $_POST['cost'];
$description = $_POST['description'];
$image       = basename($_FILES['image']['name']);
$uploadfile  = 'pictures/temp/'.$image;
if(move_uploaded_file($_FILES['image']['tmp_name'],$uploadfile))
{
    $makesql  = "INSERT INTO make (make_id,make_name) VALUES ('',:make_name)";
    $typesql  = "INSERT INTO type (type_id,type_name) VALUES ('',:type_name)";
    $modelsql = "INSERT INTO model (model_id,make_id,type_id,caliber,model_name,cost,description,) VALUES ('',:make_id,:type_id,:caliber,:model_name,:cost,:description)";
    $imagesql = "INSERT INTO image (model_id,image_path) VALUES (:model_id,:image_path)";       
    try
    {
        /* db Connector */
        $pdo = new PDO("MysqL:host=localhost;dbname=gun",'root','');
        /* insert make information */
        $make = $pdo->prepare($makesql);    
        $make->bindParam(':make_name',$make);
        $make->execute();
        $make->closeCursor();
        $makeLastId = $pdo->lastInsertId();
        /* insert type information */
        $type = $pdo->prepare($typesql);
        $type->bindParam(':type_name',$type);
        $type->execute();
        $type->closeCursor();
        $typeLastId = $pdo->lastInsertId();
        /* insert model information */          
        $model = $pdo->prepare($modelsql);
        $model->bindParam(':make_id',$makeLastId);
        $model->bindParam(':type_id',$typeLastId);
        $model->bindParam(':caliber',$caliber);
        $model->bindParam(':model_name',$model);
        $model->bindParam(':cost',$cost);
        $model->bindParam(':description',$description);         
        $model->execute();
        $model->closeCursor();          
        $modelLastId = $pdo->lastInsertId();
        /* insert image information */
        $image = $pdo->prepare($imagesql);
        $image->bindParam(':model_id',$modelLastId);
        $image->bindParam(':image_path',$image);
        $image->execute();
        $image->closeCursor();
        print(ucwords($manu));
    }
    catch(PDOexception $e)
    {
        $error_message = $e->getMessage();
        print("<p>Database Error: $error_message</p>");
        exit(); 
    }
}
else
{
    print('Error : could not add item to database');
}

因此,当我使用上面的代码添加项目时,一切正常,但是当我使用相同的制造商名称添加另一个项目时,它将复制它.我只是想让它意识到它已经存在而不是重复它.

我正在考虑进行某种类型的检查以查看该数据是否已经存在,如果确实存在,则不输入数据,但获取id并在需要的其他表中输入该ID.

我想到的另一件事是为最有可能重复的数据创建一个下拉列表并将值指定为id.但是,我简单的头脑无法找到最好的方法:(希望所有这些都有意义,如果不是,我会尝试详细说明.

如果你有的领域只有一组极限数据(口径肯定是一个,我怀疑manfacturer也会工作)你可以预先填充数据库中的表并将其转换为查找字段.

在HTML表单上,您可以打印出一个选择框,而不是文本输入字段. select的值是查找字段中的ID – 您无需担心向数据库中的查找字段添加任何内容.

当我过去必须这样做的时候,我已经编写了一个函数来进行数据插入;它检查值是否在表中.如果是,则返回该字段的索引;否则,它将其添加为新条目,并返回新条目的ID.它不是最优雅的解决方案,但效果很好.

猜你在找的PHP相关文章