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
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();
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));
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;
}
}
}