MongoDB updating an array element in a specific index using the Java driver -


usually, avoid asking new question find "close-enough" answer problem.

but time surprisingly have fundamental , straightforward question - without lead.

i have straightforward mongodb document holds 2 arrays:

  • the 1st containing 3 numbers (ints) - each represent code-number of selected (predefined) question.

  • the 2nd holding 3 strings - answers given user these 3 correspondent questions.

for example, let's subject code 12 - "what's 1st dog's name?", , user's answer was: "spiky", etc...

so end like:

    {         "_id" : objectid("..."),         "questioncodesarray" : [                 12,                 56,                 3             ],         "answersarray" : [                 "spiky",                 "go swimming",                 "blabla.."             ]     } 

now, i'd able allow users change mind , choose different question , supply different answer it.

for this, need have index of element , access via index change using update() or findandmodify() [or other method] , answers out there "key-value style" not needed.

in simple java would've done like:

questionscodesarry[index] = newvalue; , answersarray[index] = newanswerstring;

all attempts write descent query simple index-based updating have failed.

any appreciated.

thank you.

in plain mongodb syntax need this:

collection.update({     /*your filter goes here*/ }, {     $set: {         "questioncodesarray.<zero-based-index>": "new value"     } }) 

i don't have java environment here translate driver's world. might able tonight, though.

still, vote different, more natural , less error-prone design you'd structure data so:

{     "_id" : objectid("59b635ffad44fad6662d8591"),     "answers" : [          {             "questioncode" : 12,             "answer" : "spiky"         },          {             "questioncode" : 56,             "answer" : "go swimming"         },          {             "questioncode" : 3,             "answer" : "blabla.."         }     ] } 

if that's option shall happily provide right update statement layout, too.


Comments