Linq简单查询示例

public void linq()
        {
            using (var con = new MyDbContext())
            {
                //简单的linq语法
                var q1 = from a in con.peoples where a.age > 10 orderby a.age descending select a;sql

                //简单的函数计算(count,min,max,sum)
                var q2 = (from a in con.peoples select a).Sum(d => d.age);函数

                //多列求和
                var q3 = from a in con.peoples
                         group a by new
                         {
                             name = a.name
                         } into b
                         select new
                         {
                             age = b.Sum(t => t.age),
                             id = b.Sum(t => t.id),
                             //ids = b.Select(t => t.age > 10)
                         };排序

                //排序order by desc/asc
                var q4 = from a in con.peoples where a.age > 10 orderby a.age descending select a;ip

                //top(1)
                var q5 = (from a in con.peoples where a.age > 10 select a).FirstOrDefault(); select

                //分页
                var q6 = (from a in con.peoples select a).Skip(2).Take(10);分页

                //相似like '%%'
                var q7 = from a in con.peoples where a.name.Contains("武") select a;语法

                //分组group by
                var q8 = from a in con.peoples
                         group a by a.name into a
                         select new
                         {
                             a.Key,
                             age = a.Sum(c => c.age),
                             id = a.Max(c => c.id)
                         };查询

                //链接查询 
                var q9 = from a in con.peoples
                         join b in con.peoples on a.id equals b.id
                         orderby a.id descending
                         select new { a = a, b = b };top

                //sql中的In
                var q10 = from a in con.peoples where (new int?[] { 1, 2, 3 }).Contains(a.id) select a;
            }
        }di