PHP 和 MYSQL : Inserting Foreign Key

标签 php mysql

我有两个表,IMAGES 和 CATEGORIES。

CATEGORIES 到 IMAGES 是 1:M 的关系(许多图像可以有 1 个类别)。

我想将图像从文件系统插入到数据库中,并在插入过程中动态分配外键类别。

我想通过单个插入来实现此目的,但似乎我需要为每个类别的图像插入一个,如下所示:

 $allimages = scandir('./images/all_images/');
 $category1= scandir('./images/category1/');
 $category2= scandir('./images/category2/');

//CATEGORY 1: 
for($x=0; $x<count($category1); $x++)
{   
if(!is_dir(IMAGES_PATH . $category1[$x]))   
{  
  INSERT INTO images (imgid, imgname, categoryfk) VALUES ('$x', '$category1', 1)

//CATEGORY 2: 
for($x=0; $x<count($category2); $x++)
{   
if(!is_dir(IMAGES_PATH . $category2[$x]))   
{  
  INSERT INTO images (imgid, imgname, categoryfk) VALUES ('$x', '$category2', 2)

//CATEGORY 3: 
for($x=0; $x<count($allimages); $x++)
{   
if(!is_dir(IMAGES_PATH . $allimages[$x]))   
{  
  INSERT INTO images (imgid, imgname, categoryfk) VALUES ('$x', '$allimages', 3)

这真的是我能做到的唯一方法吗?我可以在单个插入和循环中实现此类别分配吗?

谢谢!

最佳答案

此外,您还可以通过插入查找结果来动态查找外键,例如查找“类别 1”的外键,然后插入引用该类别的新图像:

INSERT INTO Images(imgId, imgname, categoryFk)
   SELECT 9876, 'photo1.jpg', cat.categoryId
   FROM Category cat
   WHERE cat.categoryName = 'Category 1';

SQLFiddle here

关于PHP 和 MYSQL : Inserting Foreign Key,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12585614/

相关文章:

表中的 PHP 数组使用 implode()

php - Windows Post 到 LInux、流解释、特殊字符

php - YII - 我们如何获取 Controller 中 init() 函数中的方法名称?

支持 PHP Linux 安全模式的文件检查

mysql - 使用mysql数据有条件批处理文件重命名

mysql - 将 sqldump 导入 docker-container

php - 如何重定向到 Wordpress 中的不同管理页面?

java - 需要帮助将标准 SQL 查询转换为 JPA Criteria 查询

mysql - sql选择现在之前的最大日期

mysql - 如何阻止mySQL用户调用 "show"函数