.Net Core 实体生成器
实体生成器是什么?
实体生成器的功能就是自动将数据库中的表以及字段 转化成我们 高级编程语言中的实体类。
我们为什么要用实体生成器
在.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 实体生成器的更多相关文章
- CSharp实体生成器
专门为C#开发人员定制的一个实体生成器,以往的生成器功能达到了,但是很多细节未考虑到,所以我借鉴“先人”的一些已有的东西,重新定制了一个.当然,需要源码的同学,直接使用IL Spy这个小工具就可以看到 ...
- 【低码】asp.net core 实体类可生产 CRUD 后台管理界面
前言介绍 喜欢小规模团队的"单打独斗",有的时候即使在大公司,也经常做着3-5个人团队的小项目,相信很多人有类似的经历. 本文介绍如何将项目中已存在的[实体类],直接生产出 CRUD 后台管理界面. ...
- oledb,odbc简易实体生成器.
DataSet to code file(C#)工具. 方便自己写的odbc或者oledb的东西用的. sql server或者oracle等大数据库已经有EF的支持. 一些其他数据库还是用oledb ...
- 对Entity Framework Core的一次误会:实体状态不跟踪
在 Entity Framework 中,当通过 EF 使用 LINQ 查询获取到一个实体(实际得到的是 EF 动态生成的实体类的代理类的实例)时,这个实体的状态默认是被跟踪的.所以,当你修改实体的某 ...
- EF Core 中多次从数据库查询实体数据,DbContext跟踪实体的情况
使用EF Core时,如果多次从数据库中查询一个表的同一行数据,DbContext中跟踪(track)的实体到底有几个呢?我们下面就分情况讨论下. 数据库 首先我们的数据库中有一个Person表,其建 ...
- EF Core 2.0中如何手动映射数据库的视图为实体
由于Scaffold-DbContext指令目前还不支持自动映射数据库中的视图为实体,所以当我们想使用EF Core来读取数据库视图数据的时候,我们需要手动去做映射,本文介绍如何在EF Core中手动 ...
- EF Core中怎么实现自动更新实体的属性值到数据库
我们在开发系统的时候,经常会遇到这种需求数据库表中的行被更新时需要自动更新某些列. 数据库 比如下面的Person表有一列UpdateTime,这列数据要求在行被更新后自动更新为系统的当前时间. Pe ...
- EF Core中如何通过实体集合属性删除从表的数据
假设在数据库中有两个表:Person表和Book表,Person和Book是一对多关系 Person表数据: Book表数据: 可以看到数据库Book表中所有的数据都属于Person表中"F ...
- EF Core怎么只Update实体的部分列数据
下面是EF Core中的一个Person实体: public partial class Person { public int Id { get; set; } public string Code ...
随机推荐
- [SpringBoot] 使用yaml文件实现多配置
SpringBoot 使用yaml文件实现多配置 SpringBoot利用yaml文件实现多配置有两种方式: 单个yml中编写多个配置(Multi-profile YAML Documents) 编写 ...
- 重学c#系列——对c#粗浅的认识(一)
前言 什么是c#呢? 首先你是如何读c#的呢?c sharp?或者c 井? 官方读法是:see sharp. 有没有发现开发多年,然后感觉名字不对. tip:为个人重新整理,如学习还是看官网,c# 文 ...
- python面试题二:Python 基础题
1.位和字节的关系? Byte 字节 bit 位 1Byte = 8bit 2.b.B.KB.MB.GB 的关系? 1Byte = 8bit KB 1KB=1024B MB 1MB=1024KB GB ...
- 数据可视化基础专题(三):Pandas基础(二) csv导入与导出
1.csv导入 1.1 csv导入 .read_csv()函数 pandas.read_csv(filepath_or_buffer: Union[str, pathlib.Path, IO[~Any ...
- web 部署专题(四):压力测试(二)压力测试实例 flask 四种wsgi方式对比(tornado,Gunicorn,Twisted,Gevent)
使用工具:siege 代码结构: hello.py templates |--hello.html hello.py代码: from flask import Flask, render_templa ...
- 机器学习实战基础(二十三):sklearn中的降维算法PCA和SVD(四) PCA与SVD 之 PCA中的SVD
PCA中的SVD 1 PCA中的SVD哪里来? 细心的小伙伴可能注意到了,svd_solver是奇异值分解器的意思,为什么PCA算法下面会有有关奇异值分解的参数?不是两种算法么?我们之前曾经提到过,P ...
- python 装饰器(五):装饰器实例(二)类装饰器(类装饰器装饰函数)
回到装饰器上的概念上来,装饰器要求接受一个callable对象,并返回一个callable对象(不太严谨,详见后文). 那么用类来实现也是也可以的.我们可以让类的构造函数__init__()接受一个函 ...
- Nginx to start, restart, shutdown and upgrade
1.start cd usr/local/nginx/sbin ./nginx 2.restart kill -HUP PID #主进程号或进程号文件路径 #或者使用 cd /usr/local/ng ...
- 关于报错,Whoops! Lost connection to ws://XXX.XXX.XXX.XXX:15684/ws
昨天,在玩rabbitMQ时候,用stompJS从web连接ranbbitMQ时,报了标题的错误消息! 我把我这个html页面代码贴上,简单得讲,就是断开后,重新连接即可.
- bzoj1680[Usaco2005 Mar]Yogurt factory*&&bzoj1740[Usaco2005 mar]Yogurt factory 奶酪工厂*
bzoj1680[Usaco2005 Mar]Yogurt factory bzoj1740[Usaco2005 mar]Yogurt factory 奶酪工厂 题意: n个月,每月有一个酸奶需求量( ...