首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在使用linqtosql和内部连接时,您只能返回列的一个子集吗?

在使用linqtosql和内部连接时,您只能返回列的一个子集吗?
EN

Stack Overflow用户
提问于 2009-06-29 19:14:27
回答 2查看 61关注 0票数 0

在使用linqtosql和内部连接时,您可以只返回列的一个子集,还是可以拉入所有列/属性?

有时你只需要2-3列,让它拉回所有15列似乎有点过分了。

EN

回答 2

Stack Overflow用户

发布于 2009-06-29 19:20:17

好的

代码语言:javascript
复制
var query =
  from c in db.Customers
  join o in db.Orders on c.CustomerID equals o.CustomerID
  select new {c.Name, o.OrderDate};
票数 3
EN

Stack Overflow用户

发布于 2009-06-29 19:23:58

这就是投影(匿名类型)的用途。您只需执行以下操作:

代码语言:javascript
复制
from p in People
select new { p.Name, p.Age }

有了联接,仍然可以使用匿名类型。如果要表示一对多关系,只需执行以下操作:

代码语言:javascript
复制
var query =
  from c in db.Customers
  join o in db.Orders on c.CustomerID equals o.CustomerID into g
  select new {c.Name, Orders = g };

但是,这会导致您在第一次为客户访问订单时执行对数据库的新查询。

如果您只是想要扁平化结构,请删除分组,然后直接投影到新的匿名类型like others have suggested

代码语言:javascript
复制
var query =
  from c in db.Customers
  join o in db.Orders on c.CustomerID equals o.CustomerID
  select new {c.Name, o.OrderDate};
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1059969

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档