В БД есть таблица 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.
Обновлять
Я отредактировал этот вопрос и запросил его повторное открытие, потому что ситуация также возникает при первом подходе модели, когда сопоставление таблиц выполняется в файле EDMX вместо отмеченной здесь аннотации:
Окно Model Browser показывает Package
в типах сущностей Model и Store, а сопоставление таблицы сущности показывает каждое свойство, правильно сопоставленное со столбцом таблицы. Это то же самое сопоставление, которое достигается с помощью стиля аннотаций с первым кодом.