我想将json文档置于下面的代码中;
string CollectionName = "Collection";
MongoClientSettings settings = MongoClientSettings.FromUrl(
new MongoUrl(MongoDbConnectionString)
);
settings.SslSettings =
new SslSettings() { EnabledSslProtocols = SslProtocols.Tls12 };
var mongoClient = new MongoClient(settings);
var db = mongoClient.GetDatabase(MongoDbDatabaseName);
var collection = db.GetCollection<BsonDocument>(CollectionName);
// id that I want to set.
var id = Guid.NewGuid().ToString();
var _id = Guid.NewGuid().ToString();
JObject jObject = new JObject(
new JProperty("id", id), // Id test 1
new JProperty("_id", _id), // Id test 2
new JProperty("property1", "value1"),
new JProperty("property2", "value2"));
BsonDocument newDoc = BsonDocument.Parse(jObject.ToString());
// upsert reference: http://stackoverflow.com/q/7240028/361100
var result = collection.ReplaceOne(
filter: new BsonDocument("id", jObject["id"].Value<string>()),
options: new UpdateOptions { IsUpsert = true },
replacement: newDoc);
id
是我想手动设置的值,但结果如下;
{
"$id": "0106669b-9670-4547-a2a3-f7ea800fac0d", // Id test 1
"_id": "9eb71b3e-83be-4dd9-b037-269d59cbe5e4", // Id test 2
"id": "9a0a4b90-5be7-44b7-af05-e3bbe08dc25e", // system generated
"property1": "value1",
"property2": "value2",
"_rid": "I2ECAKbBewAEAAAAAAAAAA==",
"_self": "dbs/I2ECAA==/colls/I2ECAKbBewA=/docs/I2ECAKbBewAEAAAAAAAAAA==/",
"_etag": "\"0000d277-0000-0000-0000-590c557a0000\"",
"_attachments": "attachments/",
"_ts": 1493980531
}
我的id
值放在$id
属性中,这不是我预期的,文档中的属性id
由系统生成。
注意
我测试了id
和_id
,但所有这些都没有设置为DocumentDB "id"
。
如果我只放置属性名id
,DocumentDB .NET库允许自己设置id
。如何使用MongoDB .NET驱动程序?
答案 0 :(得分:1)
在MongoDB中,文档的ID是&#34; _id&#34;而不是&#34; id&#34;。要获得预期的行为,您需要添加名为==&#34; _id&#34;的新JProperty。
JObject jObject = new JObject(
new JProperty("_id", id),
new JProperty("id", id),
new JProperty("property1", "value1"),
new JProperty("property2", "value2"));