EF Core CLI的具体应用-DB Frist-模型更新

2023-10-11 05:10

本文主要是介绍EF Core CLI的具体应用-DB Frist-模型更新,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在前文中,我们成功的将数据库表结构映射到我们的模型中,但是在开发阶段我们的表结构会经常发生变动,那如果表结构发生了变动,我们的模型如果没有进行更新的话,可能会出现问题。

现在我们一起来看看如果表结构发生变动,我们如何将变更更新到模型

首先我们有两种选择,第一种就是表结构的变动很小,这个时候我们可以手动更新模型

第二种就是我们接下来要重点介绍的,如果表结构变动很大,我们通过手动更新会变得非常麻烦而且容易出现错误,所以咱们程序员怎么能做这种出力不讨好的事情了,OK,跟着我的节奏,咱们开始吧!

第一步,先把表结构进行改变

我们再teacher表中添加3个字段

然后我们再添加一个新表-Student

下一步我们开始执行命令

dotnet ef dbcontext scaffold "Server=127.0.0.1;Database=School;Trusted_Connection=True;User id=sa; Password=******;" Microsoft.EntityFrameworkCore.SqlServer -o Models

出现了报错,原因是Models文件夹中已经存在了teacher文件和context文件,这个时候CLI就不知道该怎么办了,所以报个错告诉我们

那我们该怎么解决呢

我们发现之前文章中提到,有个选项是--force 是否覆盖现有的文件,这个正是我们想要的,我们来尝试一下

dotnet ef dbcontext scaffold "Server=127.0.0.1;Database=School;Trusted_Connection=True;User id=sa; Password=*****;" Microsoft.EntityFrameworkCore.SqlServer -o Models -f

OK 执行完成没有出现错误,我们来看看结果

解决方案中已经出现了Student文件,并且Teacher类中的属性也发生了变化,至此我们的问题已经基本得到了解决

现在还有个疑问,如果我们的某一个表发生了变化,我们不想针对整体数据库进行操作,只想变更某一个表的模型,我们该怎么做呢

下面咱们看一下这块该如何处理

我们发现 前文中有一个选项是 --table <TABLE_NAME> 而且可以指定多个表 现在我们尝试一下看看结果

首先我们对Student表添加一个字段 IsDelete

然后对teacher也增加字段,但是我们只想更新Student

然后执行命令

dotnet ef dbcontext scaffold "Server=127.0.0.1;Database=School;Trusted_Connection=True;User id=sa; Password=******;" Microsoft.EntityFrameworkCore.SqlServer -o Models -f -t Student

执行成功了,我们看一下我们的模型

student类已经发生了变化 但是teacher中并没有

OK,至此 我们基本上已经了解到了,如何更新的我们模型

这篇关于EF Core CLI的具体应用-DB Frist-模型更新的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/185753

相关文章

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

MyBatis ParameterHandler的具体使用

《MyBatisParameterHandler的具体使用》本文主要介绍了MyBatisParameterHandler的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、概述二、源码1 关键属性2.setParameters3.TypeHandler1.TypeHa

C#下Newtonsoft.Json的具体使用

《C#下Newtonsoft.Json的具体使用》Newtonsoft.Json是一个非常流行的C#JSON序列化和反序列化库,它可以方便地将C#对象转换为JSON格式,或者将JSON数据解析为C#对... 目录安装 Newtonsoft.json基本用法1. 序列化 C# 对象为 JSON2. 反序列化

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据