Linq To Sql类别子类别计数Performans

时间:2013-05-12 16:27:16

标签: c# linq linq-to-sql database-performance

产品表: ID名称...

类别表: ID ParentCategoryID名称

ProductCategories表: ID CatID ProdID

CatID外键和ProdID外键中的

和.. ProductCategories

多个SQL查询而不是单个查询。怎么查询? List<NameIDCountList> NameIDCountList = LINQ?

public class NameIDCount
{
    public int ID {get;set;}
    public string Name { get;set;}
    public int Count { get;set;}
}

public class NameIDCountList
    {
        public NameIDCount _Category { get; set; }
        public List<NameIDCount> _SubCategories { get; set; }
    }

我的方法:

public List<NameIDCountList> getCategories(int CatID)
            {


            List<NameIDCountList> CategoryModel = new List<NameIDCountList>();

            List<NameIDCount> MainCats = (from k in data.Categories.Where(p => p.ParentCategoryID == CatID && p.ID != 0 && p.isActive).Select(p => new NameAndID{ Name = p.Name, ID = p.ID}).ToList()
                                                                   join uk in data.ProductCategoriries
                                                                   on k.ID equals uk.catID
                                                                   join u in Product
                                                                   on uk.ProdID equals u.ID
                                                                   group u by k into grp
                                                                   orderby grp.Key.AD
                                                                   select new NameIDCount
                                                                   {
                                                                       Name = grp.Key.Name,
                                                                       ID = grp.Key.ID,
                                                                       _COUNT = grp.Count()
                                                                   }).ToList();


            foreach (var cat in MainCats)
                        {
                            NameIDCountList cm =
                                new NameIDCountList()
                                {
                                    __Category = cat,
                                    _SubCategories = (from k in data.Categories.Where(p => p.ParentCategoryID == cat.ID && p.isActive).Select(p => new NameAndID{ Name = p.Name, ID =p.ID}).ToList()
                                                                   join uk in data.ProductCategoriries
                                                                   on k.ID equals uk.catID
                                                                   join u in Product
                                                                   on uk.ProdID equals u.ID
                                                                   group u by k into grp
                                                                   orderby grp.Key.AD
                                                                   select new NameIDCount
                                                                   {
                                                                       Name = grp.Key.Name,
                                                                       ID = grp.Key.ID,
                                                                       _COUNT = grp.Count()
                                                                   }).ToList();
                                };
                            CategoryModel.Add(cm);
                        }
                return CategoryModel;
            }

结果:

<a href="/category/id=1">PC [23]</a>
    <a href="/category/id=4">NoteBook [2]</a>
    <a href="/category/id=5">Desktop [21]</a>
<a href="/category/id=2">Monitor [6]</a>
     <a href="/category/id=8">LED Monitor [4]</a>
     <a href="/category/id=9">LCD Monitor [2]</a>

0 个答案:

没有答案