Linq to EF join Linq to object 查询

10 篇文章 0 订阅

例子1:Linq to EF join Linq to object 查询OK,不报错。这是因为(Linq to Entity在join前,Linq to Object在join后。Object仅支持基元类型(Int32、String 和 Guid)。

List<string> str = new List<string> {"10002","2","3" };
                using (TPSModel db = new TPSModel())
                {
                    var query = from a in db.WorkerModels
                                join b in str on a.WorkerID equals b
                                select a;
                    Console.WriteLine(JsonConvert.SerializeObject(query));
                }

例子2:Linq to object join Linq to EF 查询List集合数据库对象OK(不限制特殊类型)。

var siteLineInfoList = new List<Site_LineInfo>()
{
    new Site_LineInfo() {Enable = true, LineName = "B", LineNum = "B"}

};

using (MESDB db = new MESDB())
{
    var c = (from s in siteLineInfoList
             join m in db.MesMachineConfig
            on s.LineNum equals m.LineNum
        select m).ToList();
}

例子3:Linq to object join Linq to EF select的时候用linq to object 调用本地方法getEqpDeviceByLine() 查询OK,不报错。

            List<string> str = new List<string> {"B","10001","3" };
            using (TPSModel db = new TPSModel())
            {
                var query = from a in str
                            join b in db.WorkerModels on a equals b.WorkerID
                            select new { b, c=getEqpDeviceByLine(a) };
                Console.WriteLine(JsonConvert.SerializeObject(query));

            }

例子4:Linq to EF join Linq to object select的时候用Linq to object 调用本地方法getEqpDeviceByLine() 查询NG,报错。

 List<string> str = new List<string> { "0201B101K500CXLB", "10001", "3" };
                using (TPSModel db = new TPSModel())
                {
                    var query = (from b in db.WorkerModels
                                 join a in str on b.WorkerID equals a
                             select new { b, c = getEqpDeviceByLine("")});
                        Console.WriteLine(JsonConvert.SerializeObject(query));
                }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值