上面两种方式都可以使用,而且各有好处,通过自定义类型的方式,可以使得collection中的文档有比较统一的模式;使用BsonDocument方式则可以支持更多的文档模式,也就是说如果一个collection中的文档拥有各种各样的模式,那么BsonDocument方式就会更灵活。
插入数据关于数据的插入,我们可以使用collection中的"Insert()"方法。下面插入了两条记录。可以通过BsonDocument对象方式插入,也可以通过自定义类型方式插入。
通过BsonDocument的方式,用户可以自由的定义文档的格式。例如,增加了一个“hobby”字段(Ps:不建议这么做,这样会对文档查询带来麻烦)。
BsonDocument student1 = new BsonDocument(); student1.Add("sid", 10); student1.Add("name", "Will10"); student1.Add("gender", "Male"); student1.Add("age", 26); student1.Add("hobby", new BsonArray() { "swimming","reading"}); collection.Insert(student1); Student student2 = new Student(); student2.age = 27; student2.name = "Wilber"; student2.gender = "Male"; collection.Insert(student2);
查询数据通过MongoDB driver,可以支持三种查询方法。
QueryDocument这种方式的查询,类似我们在MongoDB shell中的条件查询。例如,查询年龄大于20的学生
QueryDocument queryDocument = new QueryDocument("age", new QueryDocument("$gt",20)); foreach (var student in collection.Find(queryDocument)) { Console.WriteLine(student); }
当查询条件为多个的时候,例如,查询年龄大于20的男学生
QueryDocument queryDocument = new QueryDocument(new BsonElement("age", new QueryDocument("$gt", 20)), new BsonElement("gender","Male"));
Query BuilderQuery Builder是一种更简洁的方式,当通过这种方式查询的时候,我们需要使用driver中的builder来生成query。所以,要引用下面using语句
using MongoDB.Driver.Builders;
通过下面的语句,可以查询年龄大于20的学生
var query = Query.GT("age", 20); foreach (var student in collection.Find(query)) { Console.WriteLine(student); }
查询年龄大于20的男学生
var query = Query.And(Query.GT("age", 20), Query.EQ("gender", "Male"));
当然,我们也可以进行强类型查询,但是这种查询是有前提条件的,"要求文档中的字段必须是自定义类型字段的子集,也就是要求文档可以转化为特定类型"。例如,我们前面插入了一个文档还有"hobby"这个key,如果使用下面的方法,就会产生一个异常,提示Student类型没有hobby这个字段。
var query = Query<Student>.GT(e => e.age, 20); foreach (var student in collection.FindAs<Student>(query)) { Console.WriteLine(student); }
在这种情况下,可以使用BsonDocument类型进行查询。有一点不明白的就是Query使用Student强类型为什么不报错。
var query = Query<Student>.GT(e => e.age, 20); foreach (var student in collection.FindAs<BsonDocument>(query)) { Console.WriteLine(student); }
LINQ支持在driver的1.8 release之后,官方驱动就可以支持LINQ操作了。我们只需要通过下面的using语句,就可以支持LINQ的方式进行查询了。
using MongoDB.Driver.Linq;
所以,可以查询年龄大于20的学生,也可以通过下面方式实现(注意,同样要保证所有的document都可以转化为Student类型)