一个支持 CodeFirst/DbFirst/ModelFirst 的数据库小工具
Posted weihanli
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了一个支持 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后缀:表名的基础上加的后缀,默认为空
生成私有字段,默认为
private int id1;false
,如果为false
则使用自动属性的代码风格,反之,使用传统get;set;
风格代码,如:
``` csharp
public int Id { get; set; } //自动属性风格代码
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 ,字段注释会从属性的
Description
Attribute 中获取 - 根据需要设置是否生成数据库描述 sql
- 左侧生成表字段信息,右侧生成创建表的sql,生成的 Sql 仅供参考,请自行根据需要调整数据类型以及字段长度
- 根据已有的 Model 生成创建表的 sql ,字段注释会从属性的
Settings
- 修改默认数据库连接字符串
- 修改默认数据库类型
- 修改默认语言(1.1.0 版本需要重启应用)
插件扩展
Packages
目前的 packages:
DbTool.Core
DbTool 用于扩展的接口定义,帮助类DbTool.DbProvider.MySql
DbTool 对于 MySql 的支持DbTool.DbProvider.SqlServer
DbTool 对于 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 的数据库小工具的主要内容,如果未能解决你的问题,请参考以下文章
IOS 6 方向 - 只有一个 Viewcontroller 支持横向和纵向方向 - 否则只支持纵向