您好,登錄后才能下訂單哦!
OData協(xié)議、多么牛B的技術(shù)、
傳統(tǒng)的分頁寫習(xí)慣了,最近項(xiàng)目中,用到了 Asp.net WebAPI 2.0來做數(shù)據(jù)交互接口、至于為什么要使用WebAPI,我想只要是對OData協(xié)議有了解的朋友。只要說到WebAPI都會(huì)想到這個(gè),如果你想對它有更多的深入了解??梢砸撇讲┛蛨@(張善友大師)的介紹。 URL(http://www.cnblogs.com/shanyou/archive/2010/03/26/1697316.html)
微軟 5.5.2.0 的 System.Web.OData.dll、不支持$inlinecount的查詢、目前我也尚未找到關(guān)于Asp.net WebAPI支持OData協(xié)議的分頁解決方案(如果有朋友知道,方便的話,請與我分享、十分感謝?。?/p>
為此,要做分頁查詢,我們必須自己來寫一個(gè)分頁查詢的程序(Filter)、要支持OData協(xié)議,必須要用好微軟提供的OData 支持類庫、因?yàn)橹挥兄С?filter,$orderby的這些操作。我們自己寫的分頁才會(huì)有意義,如果不支持OData協(xié)議的這些查詢操作。查詢帥選等等。那就與傳統(tǒng)的數(shù)據(jù)交互接口一樣,就失去了WebAPI支持OData協(xié)議的真正意義啦。反正,我用過OData協(xié)議一些接口,我是覺得非常的方便,擴(kuò)展性也很好。應(yīng)該說WebAPI會(huì)是以后的一個(gè)很不錯(cuò)的服務(wù)接口解決方案、
分頁都需要什么?
分頁包含幾要素:記錄總條數(shù),每頁數(shù)量,總頁數(shù),當(dāng)前頁,數(shù)據(jù)列表。這差不多就是一個(gè)分頁結(jié)果需要包括的5要素吧。其實(shí)對于分頁來講,服務(wù)端需要返回的數(shù)據(jù)。就只有兩個(gè)。
第一:總記錄條數(shù)??傆涗洍l數(shù),必須要服務(wù)器端返回,然后客戶端可以通過自己的分頁定義,來計(jì)算出總分頁數(shù),客戶端保存自己的當(dāng)前頁碼等等。
第二:數(shù)據(jù)列表。這個(gè)必須要服務(wù)端返回吧(不述了)。
好,那下面,我們就先做第一件事兒,定義分頁對象返回結(jié)果對象。是的,正如你想象的一樣,非常簡單,就兩個(gè)屬性而已。
/// <summary> /// 定義一個(gè)分頁數(shù)據(jù)返回對象 /// ------------------------------- /// Add by hotboy 2015-5-13 11:21:49 /// </summary> public class ODataPagedResult { internal ODataPagedResult(object data, int total) { this._data = data; this._total = total; } private object _data; /// <summary> /// Get the Data object /// </summary> public object Data { get { return this._data; } private set { this._data = value; } } private int _total; /// <summary> /// Get the total count /// </summary> public int Total { get { return this._total; } private set { this._total = value; } } }
從下一篇開始,我們將一起探討OData協(xié)議的 Asp.net WebAPI具體的分頁實(shí)現(xiàn)代碼。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。