sql >> Databáze >  >> NoSQL >> MongoDB

C# MongoDB komplexní serializace třídy

Jak uložit data do MongoDB zde:Konverze ze slovníku na BsonDocument s vynecháním pole _t a trochu ho rozšířil, takže mě napadlo podělit se o úplné řešení.

Krok č. 1:

Ve své třídě jsem deklaroval 2 členy pro každou hodnotu:

// For the Hobbies object type:
[BsonIgnore] //ignore this value in MongoDB
public Dictionary<string, object> Hobbies { get; set; }

[JsonIgnore] //ignore this value in the response on Get requests
[BsonElement(elementName: "Hobbies")]
public BsonDocument HobbiesBson { get; set; }

/*********************************************************************/

// For the Collection object type:
[BsonIgnore] //ignore this value in MongoDB
public List<Dictionary<string, object>> Collection { get; set; }

[JsonIgnore] //ignore this value in the response on Get requests
[BsonElement(elementName: "Collection")]
public BsonArray CollectionBson { get; set; }

Krok č. 2

V mé metodě řadiče WebAPI pro Post

[HttpPost]
public override async Task<IActionResult> Post([FromBody] Person person)
{
    var jsonDoc = JsonConvert.SerializeObject(person.Hobbies);
    person.HobbiesBson = BsonSerializer.Deserialize<BsonDocument>(jsonDoc);

    jsonDoc = JsonConvert.SerializeObject(person.Collection);
    person.CollectionBson = BsonSerializer.Deserialize<BsonArray>(jsonDoc);

    //save
}

Krok č. 3

V mém Get požadavek Deserializuji to zpět takto:

[HttpGet("{id?}")]
public override async Task<IActionResult> Get(string id = null)
{
    var people = //get data from mongoDB
    foreach (var person in people)
    {
        var bsonDoc = BsonExtensionMethods.ToJson(person.HobbiesBson);
        person.Hobbies = JsonConvert.DeserializeObject<Dictionary<string, object>>(bsonDoc);

        bsonDoc = BsonExtensionMethods.ToJson(person.CollectionBson);
        person.Collection = JsonConvert.DeserializeObject<List<Dictionary<string, object>>>(bsonDoc);bsonDoc);
    }
    return Ok(people);
}

To vyřešilo můj problém a doufám, že to pomůže i ostatním :-)



  1. Operátor agregačního potrubí MongoDB $type

  2. Dotaz na vnořené pole MongoDB Intersection Query

  3. Chyba při odpojení souboru soketu v MongoDB 3.0 se nezdařila

  4. Nestjs:Správné schéma pro pole vnořených dokumentů v mongoose (bez výchozího _id nebo předefinovaného ObjectId)