新聞中心
學(xué)習(xí)Linq時(shí),經(jīng)常會(huì)遇到Linq語句問題,這里將介紹Linq語句問題的解決方法。

創(chuàng)新互聯(lián)公司網(wǎng)站設(shè)計(jì),為客戶量身定制各類網(wǎng)站建設(shè)業(yè)務(wù),包括企業(yè)型、電子商務(wù)型、成都響應(yīng)式網(wǎng)站建設(shè)、行業(yè)門戶型等各類網(wǎng)站,實(shí)戰(zhàn)經(jīng)驗(yàn)豐富,成功案例眾多。以客戶利益為出發(fā)點(diǎn),創(chuàng)新互聯(lián)公司網(wǎng)站制作為客戶規(guī)劃、按需定制開發(fā)符合企業(yè)需求、帶有營(yíng)銷價(jià)值的網(wǎng)絡(luò)建站方案認(rèn)真對(duì)待每一個(gè)客戶,我們不用口頭的語言來吹擂我們的優(yōu)秀,上1000+的成功案例見證著我們的成長(zhǎng)。
Navigation 類提供取得指定 Url 權(quán)限的功能,使用基本的Linq語句:
- public static int GetPermission(string Url)
- {
- var item = Links.Where(p => p.Url == Url).ToList();
- if (item.Count > 0)
- {
- return item[0].Permission;
- }
- return 0;
- }
因?yàn)?,在生?html 的時(shí)候,考慮了如果按照相應(yīng)的權(quán)限,一個(gè)分類下沒有任何項(xiàng)目,則不顯示這個(gè)分類,所以,取 Index 要復(fù)雜一些,要根據(jù)相應(yīng)的權(quán)限進(jìn)行分組,所以相應(yīng)的Linq語句也復(fù)雜一些,使用了 group by:
- public static int GetIndex(string Url, int Permission)
- {
- int id = FindCategoryId(Url);
- var item = from p in Links where (p.Permission & Permission) ==
Permission && p.Category_Id != 0- group p by p.Category_Id into g select new { Category_Id = g.Key };
- var i = item.ToList().FindIndex(p => p.Category_Id == id);
- return i < 0 ? 0 : i;
- }
- public static int FindCategoryId(string Url)
- {
- var item = Links.Where(p => p.Url == Url).ToList();
- if (item.Count > 0)
- {
- return item[0].Category_Id;
- }
- return 0;
- }
雖然我現(xiàn)在使用的是內(nèi)存里的數(shù)據(jù),不過,因?yàn)楦袷绞呛軜?biāo)準(zhǔn)的數(shù)據(jù)庫格式,所以,要把這個(gè)配置項(xiàng)放入數(shù)據(jù)庫表里,或者序列化成 XML,也都是非常方便的 —— 雖然我認(rèn)為這個(gè)必要性不高。
從實(shí)現(xiàn)來看,這個(gè)方法的速度應(yīng)該不會(huì)很快,不過,因?yàn)閿?shù)據(jù)量小,而且對(duì)于頁面來說,這些在內(nèi)存里做的手腳只能算小Case,所以沒有明顯感覺速度上有任何差異。
不過,目前對(duì)于這個(gè)方案,還有一些不滿意,比如,Hide 參數(shù)考慮改成和 Permission 相似,則可以控制每一項(xiàng)在不同權(quán)限下的顯示,比單純的全局 Hide 要靈活得多。再比如,目前沒有判斷是否會(huì)出現(xiàn)兩條分割線等等。
另外一種實(shí)現(xiàn)方案是,把數(shù)據(jù)的定義放在每一個(gè)頁面里,這樣的話,雖然設(shè)置分散到了每一個(gè)頁面,但是卻更符合實(shí)際情況,而且,頁面 Url 也可以通過反射得到,刪除頁面或者頁面改名都更簡(jiǎn)單,也許是更好的解決方案吧。以上介紹Linq語句。
【編輯推薦】
- LINQ Expression tree分析
- Linq調(diào)用數(shù)據(jù)訪問服務(wù)
- Linq實(shí)體繼承簡(jiǎn)單描述
- Linq DataContext淺談
- Linq DataLoadOptions描述
本文標(biāo)題:Linq語句問題的解決方法
文章源于:http://fisionsoft.com.cn/article/dhgecej.html


咨詢
建站咨詢
