龙空技术网

ASP.NET Core 学习记录 - EFCore MySql DBFirst 生成实体类

老码农 141

前言:

今天大家对“mysql实体”大约比较珍视,你们都想要剖析一些“mysql实体”的相关知识。那么小编同时在网络上收集了一些关于“mysql实体””的相关内容,希望我们能喜欢,姐妹们一起来了解一下吧!

单独生成实体类,再拷贝到

1、创建ef类库(设定一下命名空间namespace,与开发业务系统项目的一致),同时将项目设为启动项目,安装2个Nuget包,如下所示:

Microsoft.EntityFrameworkCore.ToolsPomelo.EntityFrameworkCore.MySql
2、生成数据库的实体和ef的DbContext对象,在项目根目录下,用到的是 scaffold-dbcontext 命令;
scaffold-dbcontext -force  "server=****;user id=root;password=****;database=****" -provider "pomelo.entityframeworkcore.mysql"

执行完成之后会生成指定的是Model ,

注意:表必须有主键,才会生成,如果没有主机会报 unable to generate entity type for table “xxxxxxxx”的警告,当然实体也不会生成出现的问题:如果有表字段为 datetime类型的,生成的时候会报错 应输入标识符,处理方法:把.()去掉。

3、输出到指定文件目录(Models)下:

scaffold-dbcontext -force  "server=****;user id=root;password=****;database=****" -provider "pomelo.entityframeworkcore.mysql" -OutputDir Models
4、加 -f 强制覆盖文件
scaffold-dbcontext -force  "server=****;user id=root;password=****;database=****" -provider "pomelo.entityframeworkcore.mysql" -OutputDir Models -f
5、查看反向生成命令帮助:
dotnet ef dbcontext scaffold -h

结果:

Usage: dotnet ef dbcontext scaffold [arguments] [options]Arguments:  <CONNECTION>  The connection string to the database.  <PROVIDER>    The provider to use. (E.g. Microsoft.EntityFrameworkCore.SqlServer)Options:  -d|--data-annotations                  Use attributes to configure the model (where possible). If omitted, only the fluent API is used.  -c|--context <NAME>                    The name of the DbContext. Defaults to the database name.  --context-dir <PATH>                   The directory to put the DbContext file in. Paths are relative to the project directory.  -f|--force                             Overwrite existing files.  -o|--output-dir <PATH>                 The directory to put files in. Paths are relative to the project directory.  --schema <SCHEMA_NAME>...              The schemas of tables to generate entity types for.  -t|--table <TABLE_NAME>...             The tables to generate entity types for.  --use-database-names                   Use table and column names directly from the database.  --json                                 Show JSON output. Use with --prefix-output to parse programatically.  -n|--namespace <NAMESPACE>             The namespace to use. Matches the directory by default.  --context-namespace <NAMESPACE>        The namespace of the DbContext class. Matches the directory by default.  --no-onconfiguring                     Don't generate DbContext.OnConfiguring.  --no-pluralize                         Don't use the pluralizer.  -p|--project <PROJECT>                 The project to use. Defaults to the current working directory.  -s|--startup-project <PROJECT>         The startup project to use. Defaults to the current working directory.  --framework <FRAMEWORK>                The target framework. Defaults to the first one in the project.  --configuration <CONFIGURATION>        The configuration to use.  --runtime <RUNTIME_IDENTIFIER>         The runtime to use.  --msbuildprojectextensionspath <PATH>  The MSBuild project extensions path. Defaults to "obj".  --no-build                             Don't build the project. Intended to be used when the build is up-to-date.  -h|--help                              Show help information  -v|--verbose                           Show verbose output.  --no-color                             Don't colorize output.  --prefix-output                        Prefix output with level.

对应中文注释:

<CONNECTION>数据库连接字符串。<PROVIDER>要使用的提供程序。(例如。Pomelo.EntityFrameworkCore.MySql)选项:-d |——数据注释使用属性来配置模型(如果可能)。如果省略,则只使用fluent API。-c |——context<NAME>DbContext的名称。--context dir<PATH>放置DbContext文件的目录。路径是相对于项目目录的。-f |——强制覆盖现有文件。-o |——output dir<PATH>要放入文件的目录。路径是相对于项目目录的。--模式<schema\u NAME>。。。要为其生成实体类型的表的架构。-t |——表格<表格名称>。。。要为其生成实体类型的表。--使用数据库名称直接从数据库中使用表名和列名。--json显示json输出。-p |——project<project>要使用的项目。-启动项目<project>要使用的启动项目。--framework<framework>目标框架。--配置<配置>要使用的配置。--runtime<runtime_IDENTIFIER>要使用的运行时。--msbuildprojectextensionspath<PATH>MSBuild项目扩展路径。默认为“obj”。--不生成不生成项目。仅当生成是最新的时才使用此选项。-h |--help显示帮助信息-v |——verbose显示详细输出。--无颜色不给输出着色。--使用级别前缀output prefix output。
(此处已添加书籍卡片,请到今日头条客户端查看)(此处已添加纪录片卡片,请到今日头条客户端查看)

标签: #mysql实体