EF實現分頁查詢 條件查詢 排序

2021-07-02 03:46:11 字數 1395 閱讀 5132

先來看看幾個linq to sql的幾個函式。 

take

說明:獲取集合的前n個元素;延遲。即只返回限定數量的結果集。

var q = (

from e in db.employees

orderby e.hiredate

select e)

.take(5);

語句描述:選擇所雇用的前5個雇員。

skip

說明:跳過集合的前n個元素;延遲。即我們跳過給定的數目返回後面的結果集。

var q = (

from p in db.products

orderby p.unitprice descending

select p)

.skip (10);

語句描述:選擇10種最貴產品之外的所有產品。

orderby

適用場景:對查詢出的語句進行排序,比如按時間排序 等等。

說明:按指定表示式對集合排序;延遲,:按指定表示式對集合 排序;延遲,預設是公升序,加上descending表示降序,對應的擴充套件方法是 orderby和orderbydescending

下面這個例子使用 orderby 按雇用日期對雇員進行排序:

var q =

from e in db.employees

orderby e.hiredate

select e;

說明:預設為公升序

看完這兩個函式的使用方法,那麼分頁的思路也就很容易推出來了,若要顯示第m頁,每頁n條資料,我們應該跳過n*(m-1)條資料,顯示n條資料。

原始碼如下:

/// /// 分頁查詢 + 條件查詢 + 排序

///

/// 泛型

/// 每頁大小

/// 當前頁碼

/// 總數量

/// 查詢條件

/// 排序條件

/// 是否公升序

/// iqueryable 泛型集合

public iqueryableloadpageitems(int pagesize, int pageindex, out int total, expression> wherelambda, funcorderbylambda, bool isasc)

else

}

使用示例

//查詢要求:每頁10條,顯示第2頁,查詢性別為「男」,按年齡增序排列

int totalrecord;

listresult = studentservice.loaditems(10,2,out totalrecord,u=>u.***==」男」,u=>u.age,true);

EF 分頁查詢

使用lambda表示式 建立上下文 datamodelcontainer dbcontext new datamodelcontainer 每頁5條資料,取第3頁的資料 var data dbcontext.userinfo where u u.id 1 orderby u u.id skip 5 ...

實現分頁查詢 條件查詢 全部查詢

面向介面程式設計思想 首相在dao層與service層 我們會建立 dao層的物件和service的物件 所以為了減少 量和維護方便 我們首先 在dao自定義乙個介面 然後定義 該介面的實現類 在service層中也是一樣的 然後utils層中 定義 beanfactory類 編寫bean.xml ...

用EF實現多條件查詢

基本思想 首先將資料全部查出來,然後根據搜尋條件去除資料 例項 將資料庫全部資料查出 var temp db.knowledge.asnotracking where u true 是否包含查詢模組 if string.isnullorempty moduleid decimal moduid co...