Den optimale måde i MongoDB version 3.4.
Denne version af mongod
giver $split
operatør, som selvfølgelig deler strengen som vist her
.
Vi tildeler derefter den nyligt beregnede værdi til en variabel ved hjælp af $let
variabel operatør. Den nye værdi kan derefter bruges i in udtryk for at returnere værdierne "navn" og "alder" ved hjælp af 0
for det første element og -1
for det sidste element.
Bemærk, at i in udtryk skal vi opdele det sidste element for at returnere strengen af heltal.
Til sidst skal vi gentage Cursor
objekt og cast konverter strengen af heltal til numerisk ved hjælp af Nummer
eller parseInt
og brug masseoperation og bulkWrite()
metode til $set
værdien for disse felter for maksimal effektivitet.
let requests = [];
db.coll.aggregate(
[
{ "$project": {
"person": {
"$let": {
"vars": {
"infos": { "$split": [ "$person", "," ] }
},
"in": {
"name": { "$arrayElemAt": [ "$$infos", 0 ] },
"age": {
"$arrayElemAt": [
{ "$split": [
{ "$arrayElemAt": [ "$$infos", -1 ] },
" "
]},
-1
]
}
}
}
}
}}
]
).forEach(document => {
requests.push({
"updateOne": {
"filter": { "_id": document._id },
"update": {
"$set": {
"name": document.person.name,
"age": Number(document.person.age)
},
"$unset": { "person": " " }
}
}
});
if ( requests.length === 500 ) {
// Execute per 500 ops and re-init
db.coll.bulkWrite(requests);
requests = [];
}}
);
// Clean up queues
if(requests.length > 0) {
db.coll.bulkWrite(requests);
}
MongoDB 3.2 eller nyere.
MongoDB 3.2 udfaser den gamle Bulk()
API og dets tilknyttede metoder
og giver bulkWrite()
metode, men den giver ikke $split
operatør, så den eneste mulighed, vi har her, er at bruge
var mapFunction = function() {
var person = {},
infos = this.person.split(/[,\s]+/);
person["name"] = infos[0];
person["age"] = infos[2];
emit(this._id, person);
};
var results = db.coll.mapReduce(
mapFunction,
function(key, val) {},
{ "out": { "inline": 1 } }
)["results"];
results.forEach(document => {
requests.push({
"updateOne": {
"filter": { "_id": document._id },
"update": {
"$set": {
"name": document.value.name,
"age": Number(document.value.age)
},
"$unset": { "person": " " }
}
}
});
if ( requests.length === 500 ) {
// Execute per 500 operations and re-init
db.coll.bulkWrite(requests);
requests = [];
}}
);
// Clean up queues
if(requests.length > 0) {
db.coll.bulkWrite(requests);
}
MongoDB version 2.6 eller 3.0.
Vi skal bruge den nu forældede Bulk API .
var bulkOp = db.coll.initializeUnorderedBulkOp();
var count = 0;
results.forEach(function(document) {
bulkOp.find({ "_id": document._id}).updateOne(
{
"$set": {
"name": document.value.name,
"age": Number(document.value.age)
},
"$unset": { "person": " " }
}
);
count++;
if (count === 500 ) {
// Execute per 500 operations and re-init
bulkOp.execute();
bulkOp = db.coll.initializeUnorderedBulkOp();
}
});
// clean up queues
if (count > 0 ) {
bulkOp.execute();
}