.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.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异