php中的mongodb将数组插入mongodb集合


mongodb in php-insert array to mongo db collection

我在php中使用mongodb,并且在将$subitems数组插入mongodb集合时遇到问题。

php代码:

if($_SERVER["REQUEST_METHOD"] == "POST"){
    $errors = array();
    $alarm = array();
    $item_name = data::test_input($_POST["item_name"]);
    $folder_name = data::test_input($_POST["folder_name"]);
    $subitem_num = data::test_input($_POST["subitem_num"]);

    for($i=1;$i<=$subitem_num;$i++){
        ${"subitem_name$i"} = data::test_input($_POST["subitem_name".$i]);
        ${"subitem_file$i"} = data::test_input($_POST["subitem_file".$i]);
        if(count($errors)==0){
        $subitems = array(${"subitem_name$i"}=>${"subitem_file$i"});
        }
    }
    if(empty($item_name)){
        $errors['item_name']= "insert item";
    }
    if(empty($folder_name)){
        $errors['folder_name']= "insert folder";
    }
    if(count($errors)==0){
    $query = array(
        "item_name" => $item_name,
        "status" => 0,
        "folder_name" => $folder_name,
        "subitem" => $subitems
    ); 
    $result = items::insert($query);
    if($result) $alarm['success_additem'] = "submit done";
    }
}

我希望mongodb集合的记录值如下:

{ "_id" : ObjectId("542e71b333e916542a00002e"), "item_name" : "users management", "status" :0, "folder_name" : "users", "subitem" : { "a" : "a.php","b" : "b.php" },"c" : "c.php" }

如何编写用于插入mongodb集合的php代码?

我认为您的问题是,文档中的subitem字段在插入数据库时从未包含超过一个键/值对。

for($i=1;$i<=$subitem_num;$i++){
    ${"subitem_name$i"} = data::test_input($_POST["subitem_name".$i]);
    ${"subitem_file$i"} = data::test_input($_POST["subitem_file".$i]);
    if(count($errors)==0){
    $subitems = array(${"subitem_name$i"}=>${"subitem_file$i"});
    }
}

基于for循环,您在每次迭代中都要重写$subitems。我想你的意思是在里面分配一个密钥,在这种情况下,你最好使用以下密钥:

$subitems = array();
for($i = 1; $i <= $subitem_num; $i++) {
    $key = data::test_input($_POST["subitem_name".$i]);
    $value = data::test_input($_POST["subitem_file".$i]);
    if (count($errors) == 0) {
        $subitems[$key] = $value;
    }
}

作为记录,我不知道你为什么在这里检查$errors,因为它在这个函数的顶部被分配了一次,并且似乎在for循环中没有被修改;但是,我将它保留在适当的位置,以便它与您提供的原始示例一致。

此外,实际上没有理由在这里使用动态命名的变量。$key$value等固定术语使代码可读性更强。