1

我已经成功设置了一个简单的 MVC4 互联网应用程序,它将模型数据存储到 LocalDb v11.0 SQL 服务器上。我使用代码优先的方法生成了数据库,但是,数据库中的表字段与模型数据库上下文不同。

public class Record
{
    public int Id { get; set; }
    public string PlantLocation { get; set; }
    public Plant PlantType { get; set; }
    public string Description { get; set; }
}
public class Plant
{
    public int Id { get; set; }
    public string Name { get; set; }
}
public class RecordContext : DbContext
{
    public DbSet<Record> Records { get; set; }
    public DbSet<Plant> Plants { get; set; }
}

dbo.Records Table 
[Id]            INT            IDENTITY (1, 1) NOT NULL,
[PlantLocation] NVARCHAR (MAX) NULL,
[Description]   NVARCHAR (MAX) NULL,
**[PlantType_Id]  INT            NULL,**

当我拉出表格数据时,每个字段都正确填充,PlantType_ID 显示所选植物的 ID。

  • 如果 PlantType_ID 不在我的 RecordContext 中,我应该如何使用 PlantType_ID 在我的视图中显示植物的 ID(甚至使用此存储的数据)?

我尝试了以下方法来尝试获取 ID,但无济于事:

        @Html.DisplayFor(modelItem => item.PlantType.Id)

如果有人想知道,我不会收到构建错误或运行时错误。任何见解都值得赞赏。

4

3 回答 3

2

添加virtual到植物属性以允许延迟加载:

public virtual Plant PlantType { get; set; }

为避免N+1问题,您可以指示 EF 将 PlantType 记录作为同一初始查询的一部分带回。就像是:

var record = db.Records.Include("PlantType").First();

我们有一个扩展方法可以使用 lambdas 使它更好一点:

var record = c.Records.Include(i => i.PlantType).First();

public static class Extensions
{
    public static IQueryable<T> Include<T, TProperty>(this IQueryable<T> source, Expression<Func<T, TProperty>> path) where T : class
    {
        return System.Data.Entity.DbExtensions.Include(source, path);
    }
}

编辑

或者,如果您所追求的只是 id,您可以将以下属性添加到 Record 模型:

public int PlantTypeId { get; set; }

您的数据库结构将基本保持不变(约束名称将更改),但现在您可以将剃刀语法更改为:

@Html.DisplayFor(modelItem => item.PlantTypeId)

您现在也不需要添加include评论。

于 2013-06-07T07:28:23.363 回答
0

如果要显示植物名称,可以直接使用:

@Html.DisplayFor(modelItem => item.PlantType.Name)
于 2013-06-07T05:56:34.127 回答
0

您正在使用主键进行显示。这就是为什么它没有像上面所说的那样显示你可以使用 display for 植物类型名称和其他字段。

于 2013-06-07T06:01:55.340 回答