如何推动做一个嵌入式文档在mongodb c#驱动程序

本文关键字:文档 嵌入式 mongodb 驱动程序 一个 何推动 | 更新日期: 2023-09-27 18:08:46

我有一个问题,如何在c#中将一个文档推送到另一个文档中以创建嵌入文档。

my models look like:

 public class ModelKnjiga
{
    public ModelKnjiga() { }

    [BsonId(IdGenerator = typeof(CombGuidGenerator))] // pojavljuje  se greška kod BSON tipa podataka kod ID-a,preuzoteo s dokumentacije drivera 1.5
    public Guid Id { get; set; }
    [BsonElement("naziv")]
    public string naziv { get; set; }

    [BsonElement("autor")]
    public string autor { get; set; }

    [BsonElement("godina_izdanja")]
    public string godina_izdanja { get; set; }

    [BsonElement("izdavac")]
    public string izdavac { get; set; }
    [BsonElement("ocjena")]
    public String ocjena { get; set; }

    [BsonElement("čitam")]
    public Boolean čitam { get; set; }
    [BsonElement("završio")]
   public Boolean završio { get; set; }
}

另一个模型如下:

    public ModelKorisici () {
        KnjigaLista = new List<ModelKnjiga>();
    }

    [BsonId] // pojavljuje  se greška kod BSON tipa podataka kod ID-a,preuzoteo s dokumentacije drivera 1.5 CombGuidGenerator
    public Guid  Identifikator { get; set; }

    [BsonElement("ime")]
    public string ime { get; set; }

   [BsonElement("prezime")]
    public string prezime { get; set; }

    [BsonElement("lozinka")]
    public string lozinka { get; set; }

    [BsonElement("email")]
    public string email { get; set; }
    [BsonElement("kor_ime")]
    public string kor_ime { get; set; }
    [BsonElement("uloga")]
    public string uloga { get; set; }

    public List<ModelKnjiga> KnjigaLista { get; set; }

}

,现在我正试图将一个模型knjiga推到一个模型korisici

我正在尝试用这个方法…

  public void dodajKnjiguKorisniku(ModelKnjiga knjiga, Guid id)
    {
        MongoCollection<ModelKorisici> korisniciKolekcija = GetTasksCollectionKlijenti();
        try
        {
            var pronadiKorisnika = Query<ModelKorisici>.EQ(e => e.Identifikator, id);
            var PushPodataka = Update<ModelKorisici>.Push(e => e.KnjigaLista, knjiga);
            korisniciKolekcija.Update(pronadiKorisnika, PushPodataka);
        }
        catch (MongoCommandException ex)
        {
            string msg = ex.Message;
        }
    }

在robomongo中,对象KnjigaLista总是Null…

有人能帮忙吗?

如何推动做一个嵌入式文档在mongodb c#驱动程序

我认为Update是遗留的。

(在你的模型中,你不必只使用字符串。如。: godina_izdanja可以是DateTime(),也可以是某些数字格式…)

我做了一个(异步)的例子与你的模型,希望它有帮助:

class Program
    {
        static void Main(string[] args)
        {
            MainAsync(args).GetAwaiter().GetResult();
            Console.WriteLine("");
            Console.WriteLine("press enter");
            Console.ReadKey();
        }
        static async Task MainAsync(string[] args)
        {
            ModelKnjiga knga = new ModelKnjiga()
            {
                autor = "Author",
                godina_izdanja = "2015",
                izdavac = "izdavac",
                naziv = "naziv",
                ocjena = "20",
                završio = true,
                čitam = true
            };
            ModelKnjiga knga2 = new ModelKnjiga()
            {
                autor = "Author2",
                godina_izdanja = "2016",
                izdavac = "izdavac2",
                naziv = "naziv2",
                ocjena = "202",
                završio = false,
                čitam = false
            };
            ModelKnjiga knga3 = new ModelKnjiga()
            {
                autor = "Author3",
                godina_izdanja = "2017",
                izdavac = "izdavac3",
                naziv = "naziv3",
                ocjena = "203",
                završio = false,
                čitam = true
            };
            ModelKorisici mcor = new ModelKorisici()
            {
                email = "no@where.com",
                ime = "ime",
                KnjigaLista = new List<ModelKnjiga>() { knga, knga2 },
                kor_ime = "kor_ime",
                uloga = "uloga",
                lozinka = "lozinka",
                prezime = "prezime"
            };
            var client = new MongoClient();
            var db = client.GetDatabase("KnjigaDB");
            var korisici = db.GetCollection<ModelKorisici>("Korisici");
            //After first run comment this line out
            await korisici.InsertOneAsync(mcor);

            //After first run UNcomment these lines
            //var filter = Builders<ModelKorisici>.Filter.Eq("email", "no@where.com");
            //var update = Builders<ModelKorisici>.Update.Push("KnjigaLista", knga3);
            //await korisici.UpdateOneAsync(filter, update);
        }
    }

如果你不喜欢async,把最后一行改成:

korisici.UpdateOne(filter, update);