這裏介紹Linq使用Group By和Count獲得每一個CategoryID中產品的數量,Linq使用Group By和Count獲得每一個CategoryID中斷貨產品的數量等方面。html
學常常會遇到Linq使用Group By問題,這裏將介紹Linq使用Group By問題的解決方法。函數
1.計數spa
var q =翻譯
from p in db.Productshtm
group p by p.CategoryID into g對象
select new {blog
g.Key,ip
NumProducts = g.Count()get
};產品
語句描述:Linq使用Group By和Count獲得每一個CategoryID中產品的數量。
說明:先按CategoryID歸類,取出CategoryID值和各個分類產品的數量。
2.帶條件計數
var q =
from p in db.Products
group p by p.CategoryID into g
select new {
g.Key,
NumProducts = g.Count(p => p.Discontinued)
};
語句描述:Linq使用Group By和Count獲得每一個CategoryID中斷貨產品的數量。
說明:先按CategoryID歸類,取出CategoryID值和各個分類產品的斷貨數量。 Count函數裏,使用了Lambda表達式,Lambda表達式中的p,表明這個組裏的一個元素或對象,即某一個產品。
3.Where限制
var q =
from p in db.Products
group p by p.CategoryID into g
where g.Count() >= 10
select new {
g.Key,
ProductCount = g.Count()
};
語句描述:根據產品的―ID分組,查詢產品數量大於10的ID和產品數量。這個示例在Group By子句後使用Where子句查找全部至少有10種產品的類別。
說明:在翻譯成SQL語句時,在最外層嵌套了Where條件。
4.多列(Multiple Columns)
var categories =
from p in db.Products
group p by new
{
p.CategoryID,
p.SupplierID
}
into g
select new
{
g.Key,
g
};
語句描述:Linq使用Group By按CategoryID和SupplierID將產品分組。
說明:既按產品的分類,又按供應商分類。在by後面,new出來一個匿名類。這裏,Key其實質是一個類的對象,Key包含兩個Property:CategoryID、SupplierID。用g.Key.CategoryID能夠遍歷CategoryID的值。
5.表達式(Expression)
List<Maticsoft.Model.V_StripFQCPrint> FQC_Lot_no = FQCList.OrderBy(O => O.Lot_n).ThenBy(T => T.YXLevel).ThenBy(T => T.Colors).ToList();
var q = from p in FQC_Lot_no group p by new { p.YXLevel, Criterion = int.Parse(p.Colors) <= 10 } into g select new { g.Key, newcount = g.Count() };//按YXLevel 和 p.Colors) 大於10 小於10分類。
foreach (var item in q) { dicZlot_no.Add(item.Key.ToString(), item.newcount); }////把分出來的序列放入字典