Entityset

一对多的表关系:
var q =
    from c in db.Customers
    from o in c.Orders
    where c.City == "London"
    select o;
Customers与Orders是一对多关系。即Orders在Customers类中以EntitySet形式出现。所以第二个from是从c.Orders而不是db.Orders里进行筛选。
我不明白,c怎么调用到Orders这个表?还有EntitySet是什么来的?

 

超:

 

这是仅返回订单的情况,
若要既返回订单,也返回客户名,
则需要用到并联 join 查询。

EntitySet - 筛选返回的结果集,类型为 c.Orders 对应的表的架构。
也就是说,若 c.Orders 将查询 Order 表,
那么 q 的类型是:EntitySet<Order>

db.Customers 能够“得知”c.Orders 对应的表是因为(而且必须)创建了一个关系,
这个关系可能是: c.OrderId -> Order.ID,
当建立关系后,Linq To Sql 自动创建这个关系的结果集: c.Orders。

当存在关系后,
var q =
    from c in db.Customers
    from o in c.Orders
    where c.City == "London"
    select o;

可以理解为: 筛选出客户所在城市是“伦敦”的所有订单。

转载于:https://www.cnblogs.com/happyangle/archive/2009/01/11/1373545.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值