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;

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

posted @ 2009-01-11 00:54  赖振强  阅读(759)  评论(0编辑  收藏  举报