大家好我不知道如何将数组插入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
)
)
答案 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')";
}