1

我有两张表,IMAGES 和 CATEGORIES。

类别到图像是 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)

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

谢谢!

4

2 回答 2

3

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

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

SQLFiddle在这里

于 2012-09-25T15:14:48.047 回答
2

不确定我是否正确理解您,但据我了解,应该这样做:

INSERT INTO images 
   (imgid, imgname, categoryfk) 
VALUES 
   ('$x', '$category1', 1),
   ('$x', '$category2', 2),
   ('$x', '$allimages', 3)
于 2012-09-25T14:59:26.723 回答