LINQ 预编译语句 带JOIN 多表预查询

      //LINQ预编译 语句

第一种是只有一个结果集, 

Func<>的第一个参数是DataContent 就是你的数据实体,最后一个是返回值类型
我在后面加了.FirstOrDefault()这样只会返回一个结果,userdatas是我自定义的实体类如果要返回多个结果集,请往下看

 

    class userdatas {
            public userinfo _userinfo;
            public friends _friends;
        }



</pre><pre name="code" class="csharp">    //LINQ预编译 语句
        private static readonly Func<cellsTimeDataContext, int, userdatas> searchByID =
            CompiledQuery.Compile((cellsTimeDataContext DataContext, int ID) => (
                       from UserInfo in DataContext.userinfo
                       where UserInfo.userID == ID
                       join Friends in DataContext.friends on ID equals Friends.userID
                       select new userdatas { _userinfo = UserInfo, _friends = Friends }
               ).FirstOrDefault()); 

第二种是可能返回多个结果集   他取消了.FirstOrDefault()

注意下面的IQueryable<myClass>   这样的话他是返回一个数据集


        private static readonly Func<cellsTimeDataContext, int, IQueryable<myClass>> searchByNameQuery =
            CompiledQuery.Compile((cellsTimeDataContext _dataContext, int ID) => (
                       from _userinfo in _dataContext.userinfo
                       where _userinfo.userID == ID
                       join _friends in _dataContext.friends on ID equals _friends.userID
                       select new myClass { s1 = _userinfo, s2 = _friends }
               ));


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值