在db中插入目录名称和文件

时间:2015-11-06 14:28:24

标签: php mysql sql

大家好我不知道如何将数组插入db。 我有功能扫描我的目录和子目录及其文件。

在我的数据库中,我需要编写目录名和文件名。

ID |  dir_name | file_name 
------------------------------
1  |  album_1  | Hero-527920799.jpg

对于扫描目录,我使用此功能:

 function scanDirectory($dir) {

   $result = array();

   $cdir = scandir($dir);
   foreach ($cdir as $key => $value)
   {
      if (!in_array($value,array(".","..")))
      {
         if (is_dir($dir . DIRECTORY_SEPARATOR . $value))
         {
            $result[$value] = scanDirectory($dir . DIRECTORY_SEPARATOR . $value);
         }
         else
         {
            $result[] = $value;
         }
      }
   }

   return $result;
} 

现在如何将所有目录和文件从foreach或while循环中拉入db?

Array
(
    [album-1] => Array
        (
            [0] => Hero-527920799.jpg
        )

    [album-2] => Array
        (
            [0] => topic-1350661050.jpg
        )

    [album-3] => Array
        (
            [0] => bigcompany.jpg
        )

    [album-4] => Array
        (
            [0] => small_animal.jpg
        )

    [album-5] => Array
        (
            [0] => little_animals.jpg
        )

)

1 个答案:

答案 0 :(得分:1)

第一种方法是在帖子的最后。 将$data设置为scanDirectory($dir)来电的结果。

方法2:

$data = scanDirectory($dir);
$result = array();
$iterator = new RecursiveIteratorIterator(new RecursiveArrayIterator($data), RecursiveIteratorIterator::LEAVES_ONLY);
foreach($iterator as $key => $value) {
    $parent_key = $iterator->getSubIterator($key)->key();
    $result[$parent_key][] = $value;
}

foreach($result as $key => $value) {
    foreach($value as $s_key => $s_value) {
        $sql = "INSERT INTO your_table (dir_name, file_name) VALUES ('$key', '$s_value')";
        //Execute $sql here
    }
}

方法3:

如果这是您的数据结构,那么您可以使用以下内容:

$data = array(
    'album-1'=>array(
        'Hero-527920799.jpg',
        'Hero2-527920799.jpg',
    ),
    'album-2'=>array(
        'topic-1350661050.jpg',
        'topic2-1350661050.jpg',
    ),
    'album-3'=>array(
        'bigcompany.jpg',
        'topic2-1350661050.jpg',
    ),
);

foreach($data as $key => $value) {
    foreach($value as $s_key => $s_value) {
        $sql = "INSERT INTO your_table (dir_name, file_name) VALUES ('$key', '$s_value')";
        echo $sql.'<br />';
        //Execute $sql here
    }
}

结果:

INSERT INTO your_table (dir_name, file_name) VALUES ('album-1', 'Hero-527920799.jpg')
INSERT INTO your_table (dir_name, file_name) VALUES ('album-1', 'Hero2-527920799.jpg')
INSERT INTO your_table (dir_name, file_name) VALUES ('album-2', 'topic-1350661050.jpg')
INSERT INTO your_table (dir_name, file_name) VALUES ('album-2', 'topic2-1350661050.jpg')
INSERT INTO your_table (dir_name, file_name) VALUES ('album-3', 'bigcompany.jpg')
INSERT INTO your_table (dir_name, file_name) VALUES ('album-3', 'topic2-1350661050.jpg')

第一种方法(不工作):

function gatherValue($value, $key, $data) {
    $data[$key][] = $value;
}

$result = new ArrayObject();
array_walk_recursive($data, 'gatherValue', $result);

foreach($result as $key => $value) {
    $sql = "INSERT INTO your_table (dir_name, file_name) VALUES ('$key', '$value')";
}