.NET Core - MVC 应用中 添加新字段

Entity Framework Code First迁移用于:

  ① 将新字段添加到模型

  ② 将新字段迁移到数据库

EF Code First自动创建数据库时,Code First将:
  ① 将表添加到数据库,从而可以跟踪数据库的架构

  ② 验证数据库与生成他的模型类是否同步。(如果不同步,EF会引发异常)

1. 向电影模型添加分级属性

  Models/Movie.cs类中添加属性 Rating,如下:

    public string? Rating { get; set; }

  Controllers/MoviesController.cs中的Create和Edit方法,同步更新[Bind]属性,将新属性Rating包括进去,如下:

    [Bind("Id,Title,ReleaseDate,Genre,Price,Rating")]

  更新视图模板,编辑Views/Movies/Index.cshtml文件并添加Rating字段,新增:

    标题头:<th>

        @Html.DisplayNameFor(model => model.Movies[0].Rating)

          </th>

    显示内容:<td>

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

           </td>

  更新Views/Movies/Create.cshtml,新增:

    <div class="form-group">
      <label asp-for="Rating" class="control-label"></label>
      <input asp-for="Rating" class="form-control" />
      <span asp-validation-for="Rating" class="text-danger"></span>
    </div>

  更新SeedData类,新增如下代码:

    Rating = "R",

  运行程序,结果报错:SqlException: Invalid column name 'Rating'.

  原因:是因为模型类与数据库表结构未同步导致的

  解决方案:Code First迁移,操作过程及代码如下:

    工具=>NuGet 包管理器>包管理器控制台=>输入命令:

    Add-Migration Rating

    Update-Database

  运行程序,Over.

    

 

posted @ 2022-07-05 10:31  大师兄被妖怪抓走了  阅读(123)  评论(0编辑  收藏  举报