我有一个包含许多字段的表,我想只获得几个单独的字段,我使用EF工作,然后在查询中添加另一个表,如下所示
var Test= ve.Folders.Include("Hosting")
.Where(a => a.Collateral!= true)
.AsEnumerable()
.Select(p => new
{
id = p.Folder_Id,
name = p.Full_Name,
add = p.Address,
date1 = p.Collateral_Date,
sName = p.Hosting._Name
})
.ToArray();
但是与第二个表关联的字段(sName = p.Hosting._Name)没有任何值查询不起作用 已经尝试过许多尝试但没有结果(当我没有选择时,一切都很有效)。
提前感谢您提供任何帮助
答案 0 :(得分:2)
有一点需要注意的是,在这种情况下,调用Select
后AsEnumerable
几乎没有什么好处,因为表中的所有数据仍然是从数据库中查询的(不仅仅是您指定的字段。
如果您想避免这种情况,并且只查询这五个字段,则可以删除AsEnumerable
电话。这意味着Select
将作为SQL查询的一部分执行。这也意味着Include
是不必要的,因为Select
将查询您想要的所有数据。
var Test= ve.Folders
.Where(a => a.Collateral!= true)
.Select(p => new
{
id = p.Folder_Id,
name = p.Full_Name,
add = p.Address,
date1 = p.Collateral_Date,
sName = p.Hosting._Name
})
.ToArray();