91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在.Net項目中對MoongoDB進行調用

發布時間:2021-03-10 14:54:02 來源:億速云 閱讀:117 作者:Leah 欄目:開發技術

今天就跟大家聊聊有關怎么在.Net項目中對MoongoDB進行調用,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

方法如下:

1、安裝.Net 驅動:Install-Package MongoDB.Driver

2、數據插入 ,鏈接數據庫  

//新建Person測試類
 public class Person
 {
  public long Id { get; set; }
  public int Age { get; set; }
  public string Name { get; set; }
  public int Height { get; set; }
  public TestPerson t1{ get; set; }
 }
 public class TestPerson {
  public string Name { get; set; }
 }
 public class ObjectPerson {
  public ObjectId Id { get; set; }
  public int Age { get; set; }
  public string Name { get; set; }
  public int Height { get; set; }
 }
MongoClient client = new MongoClient("mongodb://127.0.0.1");
 IMongoDatabase database = client.GetDatabase("TestDb");//相當于數據庫
 IMongoCollection<Person> collection = database.GetCollection<Person>("Persons");//大致相當于表
 Person p1 = new Person()
 {
 Id = 2,
 Name = "test1",
 Age = 29,
 Height=130
 };   
 collection.InsertOne(p1);//單條插入也支持異步方法,后面建議都用異步的!習慣成自然!

回到客戶端工具刷新一下,就能看到新插入的數據,MongoDB 會自動創建“數據庫” 以及 Collection(約等于“表”)。MongoDB 默認用 id 做主鍵,因此不用顯式指定 id 是主鍵。

怎么在.Net項目中對MoongoDB進行調用

MongoDB 中沒有內置“自增字段”,可以把 Id 聲明為 ObjectId 類型(using MongoDB.Bson) 這樣插入以后就自動給字段賦值。

 //多條插入
 IMongoCollection<ObjectPerson> collection1 = database.GetCollection<ObjectPerson>("ObjectPersons");//大致相當于表
 List<ObjectPerson> persons = new List<ObjectPerson>() { new ObjectPerson() { Name = "test2", Age = 30, Height = 135 }, new ObjectPerson() { Name = "test3", Age = 31, Height = 140 } };
 collection1.InsertMany(persons);//多條插入

怎么在.Net項目中對MoongoDB進行調用

MongoDB 是用 json 保存的,因此也可以直接以 json 格式插入,用 BsonDocument 來代表:

IMongoCollection<BsonDocument> dogs = database.GetCollection<BsonDocument>("Dogs");
string jsondata = "{id:8999,Age:81,Name:'japan',gender:true}";
BsonDocument p2 = BsonDocument.Parse(jsondata);
dogs.InsertOne(p2);

怎么在.Net項目中對MoongoDB進行調用

還可以插入有嵌套關系的對象,比如學生和老師,注意不會有表間關系,都是存到一個集合中,注意和關系庫不一樣。

IMongoCollection<Person> collection = database.GetCollection<Person>("Persons");//大致相當于表
Person p1 = new Person()
{
 Id = 2,
 Name = "test1",
 Age = 29,
 Height=130,
 t1=new TestPerson() { Name="222"}
};   
 collection.InsertOne(p1);//單條插入

怎么在.Net項目中對MoongoDB進行調用

3、MongoDB查詢

IMongoCollection<Person> collection = database.GetCollection<Person>("Persons");
var filter = Builders<Person>.Filter.Gt(p => p.Age,5);
var filter1 = Builders<Person>.Filter.And(Builders<Person>.Filter.Gt(p => p.Age, 5), Builders<Person>.Filter.Eq(p => p.Id, 1));// And 并且 還有or方法
var filter2 = Builders<Person>.Filter.Where(p => p.Age > 5 && p.Id == 1);//和上面的寫法是一樣的但是,建議用Where方法
 //普通查詢
var result= collection.Find(filter).ToList();
foreach (var item in result)
{
 Console.WriteLine(item.Age + item.Name);
}

除了 Gt,還有 Gte、In、Lt、Lte、Ne、Nin、Near、NearSphere、Or、Where、And、Not。 當然最常用的還是 Where 操作:

 異步查詢

//異步查詢
 using (IAsyncCursor<Person> personsCursor = await collection.FindAsync<Person>(filter)) {
 while (personsCursor.MoveNextAsync().Result)//獲取下一組數據,相當于是否有指針,MongoDB其實是返回一個組,不像sql每次是一次次取
 {
 IEnumerable<Person> items = personsCursor.Current;//返回當前組的數據
 foreach (var item in items)
 {
  Console.WriteLine(item.Age + item.Name);
 }
 }
 //如果數據量不大,可以直接tolist
 var results = personsCursor.ToList();
}

  為什么 FindAsync 不直接返回集合,而是要 MoveNext 之后返回一個集合呢?因為返回 的數據量可能很大,因此 MongoDB 是分批下載,下載一批之后執行 GET_More 操作返回下 一批。可以通過 FindOptions 參數的 BatchSize 設置每一批的大小。

  如果確認返回的數據量 不大,可以 var ps = await personsCursor.ToListAsync()(或者 ToEnumerable()等)一下子返回所有數據。還有 Any、First、FirstOrDefault 等以及異步操作。需要注意 MongoDB 中查詢區分大小寫。

4、分頁查詢

//分頁
FindOptions<Person, Person> findop = new FindOptions<Person, Person>();
findop.Limit = 3;//取最多幾條
findop.Skip = 2;//跳過幾條
findop.Sort = Builders<Person>.Sort.Ascending(p => p.Age).Ascending(p => p.Name);//排序
using (var cursor = collection.FindAsync(filter, findop).Result)
{
 var items = cursor.ToList();
 foreach (var item in items)
 {
 Console.WriteLine(item.Age + item.Name);
 }
}

  指定排序規則 findop.Sort = Builders<Person>.Sort.Ascending(p => p.Age).Ascending(p => p.Name);

5、Json格式取法

//json格式取法
IMongoCollection<BsonDocument> bsonDoc = database.GetCollection<BsonDocument>("Persons");
var filter4 = Builders<BsonDocument>.Filter.Gt("Age", 5);
using (var persons=await bsonDoc.FindAsync(filter4)) 
{
 foreach (var item in await persons.ToListAsync())
 {
 Console.WriteLine(item.GetValue("Name").AsString);
 }
}

6、Update更新操作

IMongoCollection<Person> upPersons = database.GetCollection<Person>("Persons");
var upFilter = Builders<Person>.Filter.Where(p => p.Age>20);//篩選條件
var update = Builders<Person>.Update.Set(c => c.Name, "test2");//更新條件,將Name更新成test2
upPersons.UpdateMany(filter, update);

7、Delete刪除操作

IMongoCollection<Person> teachers = database.GetCollection<Person>("Persons");
var deletefilter = Builders<Person>.Filter.Where(p => p.Id == 1);
teachers.DeleteMany(deletefilter);

 用 Update 機會比較少,如果頻繁的用 Update 可能意味著用錯了;也不要想著 join、group by, 還是場景不對!

8、MongoDB 應用場景

  日志記錄系統;設備監控數據的存儲;餓了么外賣騎手接單; 存儲商品、商家信息;網站評論信息;存儲爬蟲爬過來的第三方數據;

  但是像訂單、金融交易、游戲裝備等這些關鍵信息不要用 MongoDB;

看完上述內容,你們對怎么在.Net項目中對MoongoDB進行調用有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

曲松县| 昌江| 丽水市| 龙南县| 广安市| 桃江县| 濮阳市| 蒙城县| 喀什市| 沙田区| 西华县| 鹿泉市| 安阳县| 叶城县| 阿尔山市| 彭山县| 固阳县| 汝城县| 和硕县| 巴林右旗| 随州市| 剑川县| 丰台区| 武川县| 武汉市| 宁国市| 翁牛特旗| 浦江县| 文成县| 威海市| 竹山县| 宝山区| 历史| 沙河市| 德江县| 灵宝市| 张北县| 普安县| 文安县| 驻马店市| 张家川|