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;
可以理解为: 筛选出客户所在城市是“伦敦”的所有订单。