web-dev-qa-db-fra.com

MongoDB et C # Trouver ()

J'ai le code ci-dessous et je suis nouveau sur mongodb, j'ai besoin d'aide pour trouver un élément spécifique dans la collection.

using MongoDB.Bson;
using MongoDB.Driver;
namespace mongo_console    {

public class User    {
    public ObjectId Id { get; set; }
    public string name { get; set; }
    public string pwd { get; set; }
}
class Program    {
    static void Main(string[] args)
    {
        MongoClient client = new MongoClient();
        MongoServer server = client.GetServer();
        MongoDatabase db = server.GetDatabase("Users");
        MongoCollection<User> collection = db.GetCollection<User>("users");

        User user = new User
        {
            Id = ObjectId.GenerateNewId(),
            name = "admin",
            pwd = "admin"
        };
        User user2 = new User
        {
            Id = ObjectId.GenerateNewId(),
            name = "system",
            pwd = "system"
        };
        collection.Save(user);
        collection.Save(user2);

        /*
         * How do I collection.Find() for example using the name
         */
  }
}
}

Une fois que je trouve l’utilisateur que j’aimerais imprimer, est-ce possible ou trouvera-t-il seulement le retour de la position? si oui, comment puis-je l'imprimer?

J'ai vu des exemples de collection.Find (x => x.quelque chose) mais je ne sais pas ce que x est ou signifie

3
mejia_david

Pour trouver un enregistrement, vous pouvez utiliser Lambda dans find, par exemple:

var results = collection.Find(x => x.name == "system").ToList();

Vous pouvez également utiliser des générateurs qui fonctionnent avec du texte Lambda ou un texte fortement typé:

var filter = Builders<User>.Filter.Eq(x => x.name, "system")

Ou

var filter = Builders<User>.Filter.Eq("name", "system")

Et puis utiliser trouver comme ci-dessus

// results will be a collection of your documents matching your filter criteria

// Sync syntax
var results = collection.Find(filter).ToList();

// Async syntax
var results = await collection.Find(filter).ToListAsync();
19
pieperu

Cela varie également en fonction de la version du framework .Net que nous utilisons. Si nous utilisons un pilote 2x, il devrait ressembler à ceci:

var list = await collection.Find(new BsonDocument()).ToListAsync();

méthode 2

await collection.Find(new BsonDocument()).ForEachAsync(X=>Console.WriteLine(X));

Exemple de référence

1
Lawrine
using MongoDB.Bson;
using MongoDB.Bson.Serialization.Attributes;
using MongoDB.Driver;
using MongoDB.Driver.Builders;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace Mongo_console
{
    class Program
    {
        public static void Main(string[] args)
        {
            MongoClient client = new MongoClient();
            MongoServer server = client.GetServer();
            MongoDatabase db = server.GetDatabase("admin");
            MongoCollection<Book> collection = db.GetCollection<Book>("Book");


            Book book1 = new Book
            {
                Id = ObjectId.GenerateNewId(),
                name = "Reel To Real"
            };
            Book book2 = new Book
            {
                Id = ObjectId.GenerateNewId(),
                name = "Life"
            };
            collection.Save(book1);
            collection.Save(book2);

            var query = Query<Book>.EQ(u => u.Id, new ObjectId("5a5ee6360222da8ad498f3ff"));
            Book list = collection.FindOne(query);
            Console.WriteLine( "Book Name  " + list.name);


            Console.ReadLine();
        }
    }
    public class Book
    {
        [BsonId]
        public ObjectId Id { get; set; }
        public string name { get; set; }

        public Book()
        {
        }

        public Book(ObjectId id, string name)
        {
            this.Id = id;
            this.name = name;
        }
    }
}
0
Bhagyashree Nirmale