gpt4 book ai didi

entity-framework - 实体类型 不是当前上下文模型的一部分

转载 作者:行者123 更新时间:2023-12-03 10:05:31 24 4
gpt4 key购买 nike

DB 有一个表 PackagingInfo .我有一个 Package类,和一个 ShopEntities : DbContext .

// Entity (ex. Package.cs)
[Table("PackagingInfo")]
public class Package
{
public decimal PackageID { get; set; }
public decimal Title { get; set; }
public decimal Cost { get; set; }
public bool isFree { get; set; }

}

// Entity Context (ex. ShopEntities.cs)
public class ShopEntities : DbContext
{
public DbSet<Package> Packages { get; set; }
}


// Controller Action (ex. HomeController.cs)
public ActionResult Index()
{
ShopEntities _db = new ShopEntities();
var q = _db.Packages.ToList();
return View(q);
}

实例化 _db 后上下文并检查其 Packages属性和异常被注意到:
The entity type Package is not part of the model for the current context.

更新

我已经编辑了这个问题并要求重新打开它,因为这种情况也发生在 Model first 方法中,其中表映射是在 EDMX 文件中完成的,而不是这里注意到的注释:

模型浏览器窗口显示 Package在机器人模型和商店实体类型中,实体的表映射显示每个属性正确映射到表列。这与注释代码优先样式完成的映射相同。

最佳答案

显式添加 “DatabaseGenerated”属性设置 “identity”数据库中列的值

[DatabaseGenerated(System.ComponentModel.DataAnnotations.DatabaseGeneratedOption.Identity)]

指定十进制数据类型的精度。这是因为默认情况下,它假定十进制数据类型的小数点后有两个数字。我们需要将其设置为 0。
modelBuilder.Entity<User>().Property(x => x.ID).HasPrecision(16, 0);

关于entity-framework - 实体类型 <classname> 不是当前上下文模型的一部分,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4983108/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com