Linq語句問題的解決方法
學(xué)習(xí)Linq時(shí),經(jīng)常會(huì)遇到Linq語句問題,這里將介紹Linq語句問題的解決方法。
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ù)量小,而且對于頁面來說,這些在內(nèi)存里做的手腳只能算小Case,所以沒有明顯感覺速度上有任何差異。
不過,目前對于這個(gè)方案,還有一些不滿意,比如,Hide 參數(shù)考慮改成和 Permission 相似,則可以控制每一項(xiàng)在不同權(quán)限下的顯示,比單純的全局 Hide 要靈活得多。再比如,目前沒有判斷是否會(huì)出現(xiàn)兩條分割線等等。
另外一種實(shí)現(xiàn)方案是,把數(shù)據(jù)的定義放在每一個(gè)頁面里,這樣的話,雖然設(shè)置分散到了每一個(gè)頁面,但是卻更符合實(shí)際情況,而且,頁面 Url 也可以通過反射得到,刪除頁面或者頁面改名都更簡單,也許是更好的解決方案吧。以上介紹Linq語句。
【編輯推薦】