wpf和ef选择包含include的表的一部分

时间:2013-05-01 18:34:09

标签: c# wpf entity-framework

我有一个包含许多字段的表,我想只获得几个单独的字段,我使用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)没有任何值查询不起作用 已经尝试过许多尝试但没有结果(当我没有选择时,一切都很有效)。

提前感谢您提供任何帮助

1 个答案:

答案 0 :(得分:2)

有一点需要注意的是,在这种情况下,调用SelectAsEnumerable几乎没有什么好处,因为表中的所有数据仍然是从数据库中查询的(不仅仅是您指定的字段。

如果您想避免这种情况,并且只查询这五个字段,则可以删除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();