.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 @   大师兄被妖怪抓走了  阅读(130)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
点击右上角即可分享
微信分享提示