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;

                //简单的函数计算(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;

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

                //分页
                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 };

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

转载于:https://my.oschina.net/u/3141521/blog/3032158

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值