c#開發Mongo筆記第九篇

來源:互聯網
上載者:User

標籤:des   style   blog   io   color   ar   os   使用   sp   

用skip略過少量的文檔還是不錯的。但是要是數量非常多的話,skip就會變得很慢,因為要先找到需要被略過的資料,然後再拋棄這些資料。大多數資料庫都會在索引中儲存更多的中繼資料,用於處理skip,

但是mongoDB目前還不支援,所以要盡量避免略過太多的資料 。通常可以利用上次的結果來計算下一次的查詢條件。

最簡單的分頁方法就是用limit返回結果的第一頁,然後將每個後續頁面作為相對開始的位移量返回。

比如var page1=db.Log.find(query).skip(100).limit(100)

然而,一般來講可以找到一種不使用skip的情況下實現分頁,這取決於查詢的本身。例如。要按照時間降序顯示文檔列表。可以用如下方式擷取結果的第一頁

var page1=db.Log.find().sort({"createtime":-1}).limit(100)

然後可以利用最後一個文檔中的createTime的值最為查詢條件,來擷取下一頁

var lasttime=null;

while(page1.hasnext()){

lasttime=page1.next();

}

var page2=db.Log.find({"createtime":{"$gt":createtime.createtime});

page2.sort({"createtime":-1}).limit(100);

那麼在c#中我覺得大概應該就是這麼實現,當然了這隻是個示範,肯定是不能在這個函數中查詢上次的結果的,不然又重新查詢了,直接把上次查詢結果傳過來就好‘

   public static List<Log> GetList(IMongoQuery query, int pagesize, int pagenum)        {            MongoDatabase db = MongoHelperFactory.GetDataBase();            MongoCollection collection = db.GetCollection<Log>("Log");            if (pagenum==0)            {                return collection.FindAs<Log>(query).OrderByDescending(l => l.CreateTime).Take(pagesize).ToList();            }            else            {                                DateTime lastTime = collection.FindAs<Log>(query).OrderByDescending(l => l.CreateTime).Take(pagesize * pagenum).Min(l => l.CreateTime);                return collection.FindAs<Log>(query).Where(l => l.CreateTime < lastTime).OrderByDescending(l => l.CreateTime).Take(pagesize).ToList();            }                }

調用方法是這樣的

 int SkipNum = Convert.ToInt32(Request.Form["page"]) - 1;            int TakeNum = Convert.ToInt32(Request.Form["rows"]);            string searchstr = "";// Request.QueryString["condition"];            IMongoQuery query = null;            if (Request.QueryString["condition"] != null)            {                searchstr = Request.QueryString["condition"];                query = Query<Log>.Matches(c => c.Description, new BsonRegularExpression(new Regex(searchstr)));            }            //  List<Log> list = DAL.DALLog.GetList(query).OrderByDescending(l => l.CreateTime).ToList() ;            // return Content("{\"total\":\""+list.Count()+"\",\"rows\":"+ users.Take(TakeNum).Skip(TakeNum*SkipNum).ToJson().ToString()+"}");            StringBuilder sb = new StringBuilder();            sb.Append("{\"total\":\"" + DAL.DALLog.GetCount(query) + "\",\"rows\":[");            List<Log> list = DAL.DALLog.GetList(query, TakeNum, SkipNum);

 

c#開發Mongo筆記第九篇

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.