我坚持在现有文档中添加新字段 .
以下是我的程序AddNewField用于测试目的 .
在代码之后,您可以看到我的集合有两个文档:第一个是Before Update,第二个是After Update .
第一个(更新前)是包含所有字段的原始文档 . 最后一个(更新后)只有“_id”字段和“new_field”
最后但并非最不重要的我注意到,虽然第一个文件有“_id”:ObjectId(“509a2d81f10a00000000000a”),但最后一个文件有“_id”:“509a2d81f10a00000000000a”
我正在尝试使用特殊更新运算符$ set .
我做错了什么?
procedure AddNewField(const aGfs: TGridFS; const aGfsName: string);
var
command: IBson;
bb: IBsonBuffer;
query: IBson;
gf: IGridfile;
OID: string;
begin
gf := aGfs.find(aGfsName, False);
OID := gf.getID().AsString;
query := BSON(['_id', OID]);
bb := NewBsonBuffer;
bb.startObject(PAnsiChar('$set'));
bb.AppendStr(PAnsiChar('new_field'), PAnsiChar('The Boss wins!'));
bb.finishObject;
command := bb.finish;
FMongo.update('fsdb.fs.files', query, command, updateUpsert);
end;
在调用FMongo.Update之后,我的集合现在有两个文件!
/* Before Update */
{
"_id" : ObjectId("509a2d81f10a00000000000a"),
"filename" : "Test Document.pdf",
"length" : NumberLong(7855753),
"chunkSize" : 262144,
"uploadDate" : ISODate("2012-11-07T09:44:33Z"),
"md5" : "e803de3a59bf7098bb419e005162e950",
"flags" : 0
}
/* After Update */
{
"_id" : "509a2d81f10a00000000000a",
"new_field" : "The Boss wins!"
}