.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 ...
随机推荐
- Django---进阶13
目录 数据库表创建及同步 注册功能 登陆功能 bbs是一个前后端不分离的全栈项目,前端和后端都需要我们自己一步步的完成 表创建及同步 注册功能 forms组件 用户头像前端实时展示 ajax 登陆功能 ...
- ES6入门(一)
目录 ES6入门 (一) let 和 const 命令 let 定义 注意事项 块级作用域 不存在变量提升 let的特点就是存在暂时性死区 特殊情况的暂时性死区 之 ES6函数存在默认值情况 不允许重 ...
- day63 django入门(4)
目录 一.CBV源码解析 二.模版语法 1 传值 2 过滤器(最多只能传两个参数) 3 标签 4 自定义过滤器,标签,inclusion_tag 4.1 自定义过滤器 4.2 自定义标签(可以传多个参 ...
- scrapy 源码解析 (二):启动流程源码分析(二) CrawlerProcess主进程
CrawlerProcess主进程 它控制了twisted的reactor,也就是整个事件循环.它负责配置reactor并启动事件循环,最后在所有爬取结束后停止reactor.另外还控制了一些信号操作 ...
- 纯 CSS 实现滑动轮播图效果
只使用css实现轮播图简单的操作 <!DOCTYPE html> <html lang="en"> <head> <meta charse ...
- Python读取文件基本方法
在日常开发过程中,经常遇到需要读取配置文件,这边就涉及到一个文本读取的方法. 这篇文章主要以Python读取文本的基础方法为本,添加读取整篇文本返回字符串,读取键值对返回字典,以及读取各个项返回列表的 ...
- Nslookup命令的使用 - [详细]
用法一.查询IP地址 nslookup最简单的用法就是查询域名对应的IP地址,包括A记录和CNAME记录,如果查到的是CNAME记录还会返回别名记录的设置情况.其用法是: nslookup 域名 # ...
- oracle数据库备份还原命令
oracle数据库备份命令exp 用户名/密码@orcl file=d:\xxxxxx.dmp owner=用户名 oracle数据库还原命令sqlplus conn / as sysdba drop ...
- oracle终止用户会话
1.创建两个测试用户进行实验 执行命令如下: create user test1 identified by 1; create user test2 identified by 1; grant d ...
- iview实战 : 树形组件自定义
Tree树形组件是 iview 中相对复杂的一个组件. 自定义节点内容 使用强大的 Render 函数可以自定义节点显示内容和交互,比如添加图标,按钮等. ——官方文档 但官方的 example 只有 ...