一个支持 CodeFirst/DbFirst/ModelFirst 的数据库小工具
一个支持 CodeFirst/DbFirst/ModelFirst 的数据库小工具
Intro
DbTool 是一个支持 CodeFirst/DbFirst/ModelFirst 的数据库小工具,原本是基于 dotnet framework WinForm 实现的,在 1.1.0 版本更新中使用 dotnet core 3.1 基于 WPF 重写了,并实现了一个简单的基于插件模式开发模式并引入了多语言的基础支持。
数据库当前支持 SqlServer 和 MySql,可以自己扩展其他类型数据库。
可以利用这个小工具生成数据库表对应的 Model,并且会判断数据表列是否可以为空,可以为空的情况下会使用可空的数据类型,如 int? , DateTime? ,如果数据库中有列描述信息,也会生成在属性名称上添加列描述的注释,支持导出多个表;可以导出到Excel,可以根据Excel字段文档生成Sql,数据库表误删除又没有备份的时候就很有帮助了,而且支持反向的根据生成的Model去生成创建数据库表的Sql(供参考)。
基本功能
功能一览




功能说明
DbFirst
导出数据库表到Model
- 设置数据库连接字符串,并连接数据库
- 设置导出 Model 选项
- 选择要导出 Model 的数据库表
- 导出 Model
Model 设置选项说明:
- model的命名空间:生成的 model 所在的命名空间,默认为 Models,不可为空,为空则使用默认值Models
- model前缀:表名的基础上加的前缀,默认为空
- model后缀:表名的基础上加的后缀,默认为空
- 生成私有字段,默认为
false,如果为false则使用自动属性的代码风格,反之,使用传统get;set;风格代码,如:public int Id { get; set; } //自动属性风格代码 private int id1;
public int Id1 { get{ return id1; } set { id1 = value; } } //传统get;set风格代码
- 生成 Description Attribute,默认值为
true,如果为true则会在属性字段上生成一个[Description]的Attribute,如果为false则不生成,效果如下:/// <summary>用户名</summary>
[Description("用户名")]
public string UserName { get;set; }
- 生成 Model 名称的规则说明:生成的Model的名称由前缀和表名称及后缀拼接而成,如果表名以
tab或tab_或tbl或tbl_这些开头,则会先把这些移除掉再拼接,可以通过自定义插件扩展
导出数据库表到Excel
- 设置数据库连接字符串,并连接数据库
- 选择要导出到 Excel 的数据库表
- 导出到 Excel
ModelFirst
- 可以手动填写信息或者先选择 Excel 导入
- 只生成 Sql 语句,不会自动在数据库里创建表,根据生成的 Sql 语句再创建表
CodeFirst
- 根据已有的 Model 生成创建表的 sql ,字段注释会从属性的
DescriptionAttribute 中获取 - 根据需要设置是否生成数据库描述 sql
- 左侧生成表字段信息,右侧生成创建表的sql,生成的 Sql 仅供参考,请自行根据需要调整数据类型以及字段长度
- 根据已有的 Model 生成创建表的 sql ,字段注释会从属性的
Settings
- 修改默认数据库连接字符串
- 修改默认数据库类型
- 修改默认语言(1.1.0 版本需要重启应用)
插件扩展
Packages
目前的 packages:
DbTool.CoreDbTool 用于扩展的接口定义,帮助类DbTool.DbProvider.MySqlDbTool 对于 MySql 的支持DbTool.DbProvider.SqlServerDbTool 对于 SqlServer 的支持
扩展方式
- 扩展数据库支持,实现
IDbProvider - 扩展导出方式,实现
IDbDocExporter,当前支持导出Excel - 扩展 Model 代码生成方式,实现
IModelCodeGenerator,根据数据库表信息生成 Model - 扩展 Model 名称表名称转化,实现
IModelNameConverter,也可以继承DefaultModelNameConverter,改写某一个实现
自定义扩展使用方式
新建一个类库项目,引用 DbTool.Core,并实现相应的接口,实现对应的逻辑,将生成的 dll 放在 DbTool 的 plugins 目录下即可
举个例子,自定义一个 Markdown Exporter 插件
- 新建一个项目
DbTool.DbDocExporter.Markdown,并引用DbTool.Core - 添加
MarkdownDbDocExporter类并实现IDbDocExporter接口 dotnet build生成 dll,并将生成的 dll 放在plugins目录下



Reference
一个支持 CodeFirst/DbFirst/ModelFirst 的数据库小工具的更多相关文章
- 一个支持DbFirst、ModelFirst和CodeFirst的数据库小工具DbTool
DbTool 一个支持DbFirst.ModelFirst和CodeFirst的数据库工具. 简介 这是一个针对 SqlServer 数据库和 C# 开发语言的小工具,可以利用这个小工具生成数据库表对 ...
- 介绍一个开源的在线管理SQLServer的小工具--SQLEntMan
近来有许多人问起SQL在线管理的问题,遂将以前用过的一个开源SQL 在线管理工具修改了一下,并分享. 看下效果图: 原项目的地址:http://sourceforge.net/projects/asp ...
- ruby利用Zip Gem写一个简单的压缩和解压的小工具
在UNIX下的我们怎么会沦落到用ruby写压缩和解压工具呢?直接上shell啊!但是请允许本猫这次可耻的用ruby来玩玩吧!其实ruby GEM中有很多压缩解压包,我选的是Zip,也许是因为名字符合K ...
- 【游戏开发】Excel表格批量转换成CSV的小工具
一.前言 在工作的过程中,我们有时可能会面临将Excel表格转换成CSV格式文件的需求.这尤其在游戏开发中体现的最为明显,策划的数据文档大多是一些Excel表格,且不说这些表格在游戏中读取的速度,但就 ...
- 这些小工具让你的Android 开发更高效
在做Android 开发过程中,会遇到一些小的问题.尽管自己动手也能解决.可是有了一些小工具,解决这些问题就得心应手了,今天就为大家推荐一下Android 开发遇到的小工具,来让你的开发更高效. Vy ...
- spring MVC +freemarker + easyui 实现sql查询和执行小工具总结
项目中,有时候线下不能方便的连接项目中的数据源时刻,大部分的问题定位和处理都会存在难度,有时候,一个小工具就能实时的查询和执行当前对应的数据源的库.下面,就本人在项目中实际开发使用的小工具,实时的介绍 ...
- 利用ncurses库开发终端工具箱(1)—— ToDoList小工具开发
准备工作 腾讯云服务器(Ubuntu),C++编程语言 由于想输出界面中包含中文,所以安装库 libncursesw5,依次输入下面三行命令 sudo apt-get install libncurs ...
- 开源一个IE下获取XPath小工具,支持32/64位
背景是曾经友情支持了测试组一小段时间,发现他们使用selenium做页面的自动化测试,需要用到XPath,但IE下没有获取XPath的工具,只能在Firefox和chrome下获取,步骤还比较麻烦.而 ...
- SSDB 一个高性能的支持丰富数据结构的 NoSQL 数据库, 用于替代 Redis.
SSDB 一个高性能的支持丰富数据结构的 NoSQL 数据库, 用于替代 Redis. 特性 替代 Redis 数据库, Redis 的 100 倍容量 LevelDB 网络支持, 使用 C/C++ ...
随机推荐
- Spring Data JPA使用findAllOrderBy时踩的坑
Spring Data JPA使用findAllOrderBy时踩的坑 按照以往的编程经验,我的写法是这样的: List<ActivityEntity> findAllOrderByWis ...
- AVR单片机教程——ADC
ADC 计算机的世界是0和1的.单片机可以通过读取0和1来确定按键状态,也可以输出0和1来控制LED.即使是看起来不太0和1的PWM,好像可以输出0到5V之间的电压一样,达到0和1之间的效果,但本质上 ...
- Arrays.asList 返回值类型
public static void main(String[] args) { Integer[] datas = {1,2,3,4,5}; List<Integer> list = A ...
- Qt5学习(1)
1. In Qt, if you want to apply styles to the main window itself, you must apply it to its central ...
- creator 2.0版本对于preloadScene函数获取加载进度
有时候,当我们场景上挂载的资源过多时,我们使用cc.director.loadScene切换场景时会等一段时间才会切换过去,这对游戏的体验是相当不好的.所以我们可以使用cc.director.prel ...
- Linux之shell编程的基本使用
1.Shell shell是一个命令行解释器,它为用户提供了一个向 Linux 内核发送请求以便运行程序的系统级程序 2.shell编程打印hello world 2.1 代码部分 #!/bin/ba ...
- floj 2265 【lxs Contest #141】航海舰队
首先抠出包围了阵形的最小矩形. 将地图拉伸成一条链,即将第一行.第二行.第三行按顺序连接.阵形也可以用同样的方法处理. 那么问题转化为,给定两个 01 串 S 和 T,问每个 S 中长度为 |T| 的 ...
- 源码分析Kafka 消息拉取流程
目录 1.KafkaConsumer poll 详解 2.Fetcher 类详解 本节重点讨论 Kafka 的消息拉起流程. @(本节目录) 1.KafkaConsumer poll 详解 消息拉起主 ...
- 如何应用threejs实现立方体每个面用图片替换
var geometry = new THREE.BoxGeometry(200, 200, 200);var materialsbg = []; for (var i = 0; i < geo ...
- 【LC_Lesson2】---整数反转练习
题目描述: 给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转. 示例 1: 输入: 123 输出: 321 示例 2: 输入: -123 输出: -321 示例 3: 输入: 1 ...