我有一个具有以下架构的mysql数据库中的两个表:
相册:标题,创建日期,修改日期,相册ID(主键)
照片:标题,image_url,date_taken,imageID(主键)
我正在创建一个由php / mysql驱动的在线相册,并且我希望允许一张照片包含在多个相册中,因此我没有将相册ID放在照片中作为外键。
我这样做的唯一方法是创建第三个表,该表将imageID与albumID相关联,但是到目前为止,我还没有这样做。
我应该在第三个表上放些什么,该表将imageID与AlbumID相关联,并允许用户将一张照片放入多个相册中。
另外,如何在我的php代码中查询它到mysql数据库以显示特定相册中的所有照片? (我正在使用mysqli函数)
任何帮助将不胜感激!
提前致谢
到目前为止的代码:
<form enctype="multipart/form-data" method="post">
<?php
require_once 'config.php';
$mysqli = new mysqli(DB_HOST, DB_USER, DB_PASSWORD, DB_NAME);
if(isset($_POST['upload'])){
$caption = $_POST['caption'];
$albumID = $_POST['album'];
$file = $_FILES ['file']['name'];
$file_type = $_FILES ['file']['type'];
$file_size = $_FILES ['file']['size'];
$file_tmp = $_FILES ['file']['tmp_name'];
$random_name = rand();
if(empty($file)){
echo "Please enter a file <br>";
} else{
move_uploaded_file($file_tmp, 'uploads/'.$random_name.'.jpg');
$ret = mysqli_prepare($mysqli, "INSERT INTO photos (caption, image_url, date_taken, imageID)
VALUES(?, ?, NOW()), null");
$filename = "uploads/" . $random_name . ".jpg";
mysqli_stmt_bind_param($ret, "ss", $caption, $filename);
mysqli_stmt_execute($ret);
echo "Photo successfully uploaded!<br>";
$id = mysqli_prepare($mysqli, "INSERT into album_photo (albumID, imageID) values (?, $id)");
}
}
?>
Caption: <br>
<input type="text" name="caption">
<br><br>
Select Album: <br>
<select name="album">
<?php
$mysqli = new mysqli(DB_HOST, DB_USER, DB_PASSWORD, DB_NAME);
$result = $mysqli->query("SELECT * FROM albums");
while ($row = $result->fetch_assoc()) {
$albumID = $row['albumID'];
$title = $row['title'];
echo "<option value='$albumID'>$title</option>";
}
?>
</select>
<br><br>
Select Photo: <br>
<input type="file" name="file">
<br><br>
<input type="submit" name="upload" value="Upload">
</form>
最佳答案
您是否尝试过使用Doctrine或Eloquent之类的ORM?您可以使用它们来实现many-to-many
关系(这是您要在此处执行的操作的技术名称)。
This answer是有关如何在SQL中实现简单的多对多关系的很好的总结。
关于php - PHP mysql相册允许一张照片包含在多个相册中(数据库结构),我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/29235104/