Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/mongodb/13.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
mongodb使用PHP更新文档中的嵌套数组_Php_Mongodb_Updating_Multidimensional Array - Fatal编程技术网

mongodb使用PHP更新文档中的嵌套数组

mongodb使用PHP更新文档中的嵌套数组,php,mongodb,updating,multidimensional-array,Php,Mongodb,Updating,Multidimensional Array,文档结构示例为: { "dob": "12-13-2001", "name": "Kam", "visits": { "0": { "service_date": "12-5-2011", "payment": "40", "chk_number": "1234455", }, "1": { "service_date": "12-15-2011", "payment": "

文档结构示例为:

{
   "dob": "12-13-2001",
   "name": "Kam",

   "visits": {
     "0": {
       "service_date": "12-5-2011",
       "payment": "40",
       "chk_number": "1234455",  
    },
     "1": {
       "service_date": "12-15-2011",
       "payment": "45",
       "chk_number": "3461234",  
    },
     "2": {
       "service_date": "12-25-2011",
       "payment": "25",
       "chk_number": "9821234",  
    } 
  } 
}
我正在尝试使用以下方式仅更新就诊-2中的“付款”和就诊-1中的chk_编号:


但此更新会删除所有访问,并用仅包含付款和chk_编号的VIST覆盖它们

我不熟悉mongodb和PHP。谁能告诉我我做错了什么以及如何解决这个问题


非常感谢……。

您应该使用点符号

db.collection.update(query_criteria, 
                     {$set: {'visit.2.payment': 100, 
                             'visit.1.chk_number': 567}});
您正在做的是:

db.collection.update(query_criteria, 
                     {'visit' : {'2' : {'payment': 100}}, 
                                {'1': {'chk_number': 567}}});
它的基本意思是“找到一个文档并用这个新文档覆盖它”


我写的代码是用Javascript编写的(就像它们在MongoShell中出现的那样)。我把它留给你来翻译成正确的PHP(我不是PHP爱好者)。

你应该使用点符号

db.collection.update(query_criteria, 
                     {$set: {'visit.2.payment': 100, 
                             'visit.1.chk_number': 567}});
您正在做的是:

db.collection.update(query_criteria, 
                     {'visit' : {'2' : {'payment': 100}}, 
                                {'1': {'chk_number': 567}}});
它的基本意思是“找到一个文档并用这个新文档覆盖它”

我写的代码是用Javascript编写的(就像它们在MongoShell中出现的那样)。我把它留给你去翻译成正确的PHP(我不是一个PHP的家伙)