【发布时间】:2016-11-09 16:14:39
【问题描述】:
我有一个包含两个表的数据库:
帖子:id(主键,自动增量),title_bg,title_en,body_bg,body_en,状态,创建,更新
postimage: id(主键, 自增), post_id, name
当我不使用外键时,具有多个元素的表单可以正常工作。它将帖子的所有详细信息填充到posts表中,并且多个图像正在上传到postimage表中,但它们不相关,因此post_id字段显示0值。
当我使用此查询在 phpMyAdmin 上设置外键时:
ALTER TABLE `postimage` ADD FOREIGN KEY ( `post_id` ) REFERENCES `database_name`.`posts` ( `id` ) ON DELETE RESTRICT ON UPDATE RESTRICT ;
当我创建一个新帖子时,所有值都保存到帖子表中,除了第二个表中的图像。 postimage 表为空。
这是我的代码:
<?php
if(isset($_POST['submit'])) {
$title_bg = $_POST['title_bg'];
$title_en = $_POST['title_en'];
$body_bg = $_POST['body_bg'];
$body_en = $_POST['body_en'];
if(isset($_FILES['image'])) {
foreach($_FILES['image']['name'] as $key => $name) {
$image_tmp = $_FILES['image']['tmp_name'][$key];
move_uploaded_file($image_tmp, '../uploads/' . $name);
$query = "INSERT INTO postimage(name) ";
$query .= "VALUES('$name')";
$upload_images = mysqli_query($connection, $query);
}
}
$status = $_POST['status'];
$query = "INSERT INTO posts(title_bg, title_en, body_bg, body_en, status, created) ";
$query .= "VALUES('$title_bg', '$title_en', '$body_bg', '$body_en', '$status', now())";
$create_post = mysqli_query($connection, $query);
header("Location: posts.php");
}
?>
<form action="" method="post" enctype="multipart/form-data">
<div class="form-item">
<label for="title_bg">Post title BG</label>
<input type="text" name="title_bg">
</div>
<div class="form-item">
<label for="title_en">Post title EN</label>
<input type="text" name="title_en">
</div>
<div class="form-item">
<label for="body_bg">Post body BG</label>
<textarea id="editor" name="body_bg" rows="10" cols="30"></textarea>
</div>
<div class="form-item">
<label for="body_en">Post body EN</label>
<textarea id="editor2" name="body_en" rows="10" cols="30"></textarea>
</div>
<div class="form-item">
<label for="image">Image</label>
<input type="file" name="image[]" multiple>
</div>
<div class="form-item">
<label for="status">Post status</label>
<select name="status">
<option value="published">published</option>
<option value="draft">draft</option>
</select>
</div>
<div class="form-item">
<input type="submit" class="form-submit" name="submit" value="Submit">
</div>
</form>
我还创建了两个新表作为测试:
教师:id、姓名、content_area、房间
学生:id、姓名、homeroom_teacher
当我在学生字段 homeroom_teacher 上设置外键并从 phpMyAdmin 手动插入数据时,它们变得相关,学生表上的 id 变得可点击,并显示与老师的关系。所以手动它工作得很好,问题出在 PHP 代码中。
我需要更改什么查询,以便与posts 表中的post id 和postimage 表中的post_id 建立连接?
我知道我缺少 $_FILES 查询中的 id,但我不知道如何获取它,因为它已经是自动自增字段。
谢谢。
【问题讨论】:
-
警告:此页面中的所有代码都可能受到 SQL 注入攻击!请阅读How to prevent SQL injection in PHP?。
标签: php mysql database phpmyadmin