Insert Array in existing Document

后端 未结 1 1427
广开言路
广开言路 2021-01-27 18:19

I have a document like this:

_id: ObjectId(\"559c1d2ad8291bc9368b4568\")
 tablename: \"IWEO_IWBB\"
 out_user: \"pb\"
 out_email: \"email\"
 out_date: \"15.05.201         


        
1条回答
  •  梦毁少年i
    2021-01-27 18:43

    There are a few things wrong in your code here. First and foremost to note is that you are running in an "async" environment now and you need to change the thinking on how you do some things.

    Your previous PHP code is "blocking", which means that every line of code must complete before moving on to the next line of code. This includes waiting for a database server to perform an update and return the response.

    You cannot use basic control loops with functions inside them that perform asynchronously. Instead you need something that can call the next iteration of the loop (or at least signal that a single iteration is complete ) once the asynchronous function "update" has actually returned a result.

    The second point here is that "nothing updated" because you did not tell the function what to update or what to update the matched document with.

    The following is analogous to you original PHP listing, but adjusted for "async" methods also use the async.eachSeries for the loop control from the async library:

    async.eachSeries(
        tables,
        function(table,callback) {
            var tablename  = table.tablename;
            delete table.tablename;   // just remove the key rather than re-construct
            OutAccept.update(
                { "tablename": tablename },
                { "$push": { "inventar": table } },
                function(err,numAffected) {
                    console.log( numAfftected ); // tells you how many are updated or nothing
                    callback(err)
                }
            );
        },
        function(err) {
           // comes here on completion of all array items
        }
    );
    

    The .findOneAndUpdate() command instead returns the document that was modified and with the modifications only if you ask for them with { "new": true }

    async.eachSeries(
        tables,
        function(table,callback) {
            var tablename  = table.tablename;
            delete table.tablename;
            OutAccept.findOneAndUpdate(
                { "tablename": tablename },
                { "$push": { "inventar": table } },
                { "new": true },
                function(err,doc) {
                    console.log( doc ); // shows the modified document
                    callback(err)
                }
            );
        },
        function(err) {
           // comes here on completion of all array items
        }
    );
    

    If you want to add Multiple array elements at once, or if you have even a single element directly in an array then use the $each modifier to $push:

    var inventor =  [
        {
            "ean": "2",
            "name": "name2",
            "runtime": "0",
            "art": "null",
            "marker": "null",
            "stammkost": "null",
            "accepted": "0"
        },
        {
            "ean": "1",
            "name": "name1",
            "runtime": "0",
            "art": "null",
            "marker": "null",
            "stammkost": "null",
            "accepted": "0"
        }
    ];
    
    
    OutAccept.update(
        { "tablename": tablename },
        { "$push": { "inventar": { "$each": inventar } } },
        function(err,numAffected) {
           // work in here
        }
    );
    

    0 讨论(0)
提交回复
热议问题