实体生成器是什么?

  实体生成器的功能就是自动将数据库中的表以及字段 转化成我们 高级编程语言中的实体类。

我们为什么要用实体生成器

  在.net core开发环境下,我们可以使用efcore这个orm来根据数据库中的表来自动生成实体类,而使用其它orm的时候,一般情况下都需要我们自己对照数据库中的表和字段,一个个添加实体类和类中的属性。因此使用实体生成器,可以减少我们重复劳动的工作量,让我们把更多的时间花在业务处理上。

实现过程:

创建实战项目EntityGenerator:

    这里我使用的VS2019开发工具,我们选择.net core控制台应用程序。

  使用json文件进行数据库的配置:

    进行nuget包安装,安装成功后可以在依赖项中查看到对应的包。

      Mysql.Data

       Microsoft.Extensions.Configuration

       Microsoft.Extensions.Configuration.Json

       Microsoft.Extensions.Configuration.Abstractions

      Microsoft.Extensions.Configuration.EnvironmentVariables

在项目根目录创建appsettings.json文件,并进行数据库连接的配置,文件内容如下图所示:

{
"ConnectionStrings": {
"TestSql": "Server=127.0.0.1;User Id=root;Password=123456;Database=Test;"
}
}

  进行数据库相关的操作

  nuget包安装,安装成功后可以在依赖项中查看到对应的包。

      Dapper

      Mysql.Data

    创建数据库访问层EntityGeneratorDao,这里用到了之前的获取json配置的IConfigurationRoot类。

    实现从数据库获取相应表的方法GetTables。

    实现从数据库获取表相应字段的方法GetSchemaTables,文件内容如下图所示:

public class EntityGeneratorDao
{
protected string ConnStr; public EntityGeneratorDao(IConfigurationRoot configurationRoot)
{
ConnStr = configurationRoot.GetSection("ConnectionStrings:TestSql").Value;
} /// <summary>
/// 获取数据库中的表
/// </summary>
/// <returns></returns>
public DataTable GetTables()
{
using(var conn = new MySqlConnection(ConnStr))
{
conn.Open();
return conn.GetSchema("Tables");
}
} /// <summary>
/// 获取表对应的字段信息
/// </summary>
/// <param name="dataRow"></param>
/// <returns></returns>
public DataTable GetSchemaTable(string tableName)
{
using (var conn = new MySqlConnection(ConnStr))
{
conn.Open();
DataTable dataTable = new DataTable(tableName);
var reader = conn.ExecuteReader($"Select * From INFORMATION_SCHEMA.COLUMNS where table_name = '{tableName}'");
dataTable.Load(reader);
return dataTable;
}
}
}

  根据获取到的字段,进行内容的拼接,文件内容如下图所示:

public class EntityGeneratorService
{
protected EntityGeneratorDao entityGeneratorDao; public EntityGeneratorService(IConfigurationRoot configurationRoot)
{
entityGeneratorDao = new EntityGeneratorDao(configurationRoot);
} /// <summary>
///
/// </summary>
/// <param name="dataTable"></param>
/// <param name="className"></param>
public string GenerateEntityContent(DataTable dataTable, string tableName, string tableComment)
{
var nameSpace = MethodBase.GetCurrentMethod().DeclaringType.Namespace;
var stringBuilder = new StringBuilder();
stringBuilder.AppendLine("using System;");
stringBuilder.AppendLine("using System.Data;");
stringBuilder.AppendLine($"namespace {nameSpace}.Entitys");
stringBuilder.AppendLine("{");
string prefix = "\t";
stringBuilder.AppendLine($"{prefix}/// <summary>");
stringBuilder.AppendLine($"{prefix}///{tableComment}");
stringBuilder.AppendLine($"{prefix}/// </summary>");
stringBuilder.AppendLine($"{prefix}public class {tableName}");
stringBuilder.AppendLine($"{prefix}{{"); string filedPrefix = "\t\t";
//默认在当前可执行目录下生成实体
foreach (DataRow dataRow in dataTable.Rows)
{
//添加注释
stringBuilder.AppendLine($"{filedPrefix}/// <summary>");
stringBuilder.AppendLine($"{filedPrefix}///{dataRow["COLUMN_COMMENT"]}");
stringBuilder.AppendLine($"{filedPrefix}/// </summary>");
string dataType = dataRow["DATA_TYPE"].ToString();
Type type = TypeExtensions.Convert(dataType); string nullableStr = type.BaseType.Name == "ValueType" && dataRow["IS_NULLABLE"].ToString() == "YES" ? "?" : "";
string defaultVlaue = dataRow["COLUMN_DEFAULT"].ToString() == string.Empty ? "" : $"={dataRow["COLUMN_DEFAULT"].ToString()};";
//添加字段声明
stringBuilder.AppendLine($"{filedPrefix}public {type.GetAliasName()}{nullableStr} {dataRow["COLUMN_NAME"]} {{ get; set; }} {defaultVlaue}");
} stringBuilder.AppendLine($"{prefix}}}");
stringBuilder.AppendLine($"}}"); return stringBuilder.ToString();
}
}

  将之前的步骤进行串联,并且将拼接的内容保存到我们的项目目录中,文件内容如下图所示:

class Program
{
static void Main(string[] args)
{
var builder = new ConfigurationBuilder()
.SetBasePath(Directory.GetCurrentDirectory())
.AddJsonFile("appsettings.json", optional: false, reloadOnChange: true)
.AddEnvironmentVariables(); var configuration = builder.Build(); EntityGeneratorDao entityGeneratorDao = new EntityGeneratorDao(configuration);
EntityGeneratorService entityGeneratorService = new EntityGeneratorService(configuration); var tables = entityGeneratorDao.GetTables(); foreach (DataRow row in tables.Rows)
{
string tableName = row["TABLE_NAME"].ToString();
string tableComment = row["TABLE_COMMENT"].ToString(); var schemaTable = entityGeneratorDao.GetSchemaTable(tableName);
string content = entityGeneratorService.GenerateEntityContent(schemaTable, tableName, tableComment);
File.WriteAllBytes($"{Directory.GetCurrentDirectory().Substring(0, Directory.GetCurrentDirectory().IndexOf("bin"))}/Entitys/{tableName}.cs",Encoding.UTF8.GetBytes(content));
} Console.ReadLine();
}
}

  

.Net Core 实体生成器的更多相关文章

  1. CSharp实体生成器

    专门为C#开发人员定制的一个实体生成器,以往的生成器功能达到了,但是很多细节未考虑到,所以我借鉴“先人”的一些已有的东西,重新定制了一个.当然,需要源码的同学,直接使用IL Spy这个小工具就可以看到 ...

  2. 【低码】asp.net core 实体类可生产 CRUD 后台管理界面

    前言介绍 喜欢小规模团队的"单打独斗",有的时候即使在大公司,也经常做着3-5个人团队的小项目,相信很多人有类似的经历. 本文介绍如何将项目中已存在的[实体类],直接生产出 CRUD 后台管理界面. ...

  3. oledb,odbc简易实体生成器.

    DataSet to code file(C#)工具. 方便自己写的odbc或者oledb的东西用的. sql server或者oracle等大数据库已经有EF的支持. 一些其他数据库还是用oledb ...

  4. 对Entity Framework Core的一次误会:实体状态不跟踪

    在 Entity Framework 中,当通过 EF 使用 LINQ 查询获取到一个实体(实际得到的是 EF 动态生成的实体类的代理类的实例)时,这个实体的状态默认是被跟踪的.所以,当你修改实体的某 ...

  5. EF Core 中多次从数据库查询实体数据,DbContext跟踪实体的情况

    使用EF Core时,如果多次从数据库中查询一个表的同一行数据,DbContext中跟踪(track)的实体到底有几个呢?我们下面就分情况讨论下. 数据库 首先我们的数据库中有一个Person表,其建 ...

  6. EF Core 2.0中如何手动映射数据库的视图为实体

    由于Scaffold-DbContext指令目前还不支持自动映射数据库中的视图为实体,所以当我们想使用EF Core来读取数据库视图数据的时候,我们需要手动去做映射,本文介绍如何在EF Core中手动 ...

  7. EF Core中怎么实现自动更新实体的属性值到数据库

    我们在开发系统的时候,经常会遇到这种需求数据库表中的行被更新时需要自动更新某些列. 数据库 比如下面的Person表有一列UpdateTime,这列数据要求在行被更新后自动更新为系统的当前时间. Pe ...

  8. EF Core中如何通过实体集合属性删除从表的数据

    假设在数据库中有两个表:Person表和Book表,Person和Book是一对多关系 Person表数据: Book表数据: 可以看到数据库Book表中所有的数据都属于Person表中"F ...

  9. EF Core怎么只Update实体的部分列数据

    下面是EF Core中的一个Person实体: public partial class Person { public int Id { get; set; } public string Code ...

随机推荐

  1. Python-日期格式化

    1.基本方法 获取当前日期:time.time() 获取元组形式的时间戳:time.local(time.time()) 格式化日期的函数(基于元组的形式进行格式化): (1)time.asctime ...

  2. linux环境下安装 openOffice4并启动服务

    一.背景故事 openOffice是用来做office文档在线预览功能,把office文档转换成pdf交给前端显示. 之前系统开发过程一直没有将springboot服务怼上服务器,所以只安装了wind ...

  3. 表格(table)数据导出成Excel

    使用xlxs-js库 function exportExcel () { var wb = XLSX.utils.table_to_book(document.querySelector('.my-e ...

  4. JVM 专题二:虚拟机(二)Java虚拟机

    2.1 什么是Java虚拟机? Java虚拟机是一台执行字节码的虚拟计算机,它拥有独立的运行机制,其运行的Java字节码也未必由Java语言编译而成. JVM平台的各种语言可以共享Java虚拟机带来的 ...

  5. 数据可视化之分析篇(九)PowerBI数据分析实践第三弹 | 趋势分析法

    https://zhuanlan.zhihu.com/p/133484654 以财务报表分析为例,介绍通用的分析方法论,整体架构如下图所示: (点击查看大图) 我会围绕这五种不同的方法论,逐步阐述他们 ...

  6. CRM【第一篇】: 权限组件之权限控制

    1. 问:为什么程序需要权限控制? 答:生活中的权限限制,① 看灾难片电影<2012>中富人和权贵有权登上诺亚方舟,穷苦老百姓只有等着灾难的来临:② 屌丝们,有没有想过为什么那些长得漂亮身 ...

  7. 02-URLConf调度器

    1.工作原理 django通过urlconf来映射视图函数,只区分路径,不区分http方法 Django确定要使用的根URLconf模块,一般是在settings中的ROOT_URLCONF设置的值. ...

  8. 使用QtCreator遇到的一些问题

    0. 背景 最近在学习QtCreator(版本:4.8.1:编译器:MSVC 2017 64-bit),遇到了一些问题,特记录如下.( 1. 引用库 QtCreator可以直接包含Windows.h, ...

  9. 2. import 与 from...import 导入模块

    1. 导入整个模块 格式: import somemodule2. 从某个模块中导入某个函数 格式: from somemodule import somefunction3. 从某个模块中导入多个函 ...

  10. Python Ethical Hacking - BeEF Framework(1)

    Browser Exploitation Framework. Allows us to launch a number of attacks on a hooked target. Targets ...