DbTool

一个支持DbFirst、ModelFirst和CodeFirst的数据库工具。


简介

这是一个针对 SqlServer 数据库和 C# 开发语言的小工具,可以利用这个小工具生成数据库表对应的 Model,并且会判断数据表列是否可以为空,可以为空的情况下会使用可空的数据类型,如int? 、DateTime? ,如果数据库中有列描述信息,也会生成在属性名称上添加列描述的注释,支持导出多个表;可以导出到Excel,可以根据Excel字段文档生成Sql,数据库表误删除又没有备份的时候就很有帮助了,而且支持反向的根据生成的Model去生成创建数据库表的Sql。

注:暂时不支持索引及外键等需要关联另外一张表的数据关系


为什么使用它

  1. [x] 根据表字段信息生成创建表 Sql(Model First)
  2. [x] 导入 Excel 文件生成创建表的 Sql(Model First)
  3. [x] 根据数据库表信息生成数据库表 Excel 文档(Db First)
  4. [x] 根据数据库表信息生成 Model 文件,支持数据列可空导出为可空数据类型/支持导出列描述信息(Db First)
  5. [x] 根据 Model 生成 sql 语句(Code First)
  6. [x] 支持一次导出多张数据表/支持一次选择多个 Model 文件(Code First)

后续功能

  • [ ] 配置化,使用配置文件保存配置以免每次都要设置参数及选项等
  • [ ] 迁移到 UWP,直接从 Win10 应用商店下载
  • [ ] 插件式自定义扩展Model信息
  • [ ] 支持 MySql

功能一览

DbFirst

ModelFirst

CodeFirst


 使用说明

      DbFirst

1、导出数据库表到Model

1)设置数据库连接字符串,并连接数据库;

2)设置导出 Model 选项;

3)选择要导出 Model 的数据库表;

4)导出 Model;

Model 设置选项说明:

model的命名空间:生成的 model 所在的命名空间,默认为 Models,不可为空,为空则使用默认值Models

model前缀:表名的基础上加的前缀,默认为空

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的名称由前缀和表名称及后缀拼接而成,如果表名以 tabtab_tbltbl_这些开头,则会先把这些移除掉再拼接。

2、导出数据库表到Excel

1)设置数据库连接字符串,并连接数据库;

2)选择要导出到 Excel 的数据库表;

3)导出到 Excel;

      ModelFirst

      可以手动填写信息或者先填写 Excel 再进行导入操作;

      只生成Sql语句,不会自动在数据库里创建表,根据生成的 Sql 语句再创建表;

      CodeFirst

      根据已有的Model生成创建表的Sql ,字段注释会从属性的Description的Attribute中获取;

      根据需要设置是否生成数据库描述Sql;

      左侧生成表字段信息,右侧生成创建表的sql,生成的Sql仅供参考,请自行根据需要调整数据类型以及字段长度;

下载DbTool

一个支持DbFirst、ModelFirst和CodeFirst的数据库小工具DbTool的更多相关文章

  1. 一个支持 CodeFirst/DbFirst/ModelFirst 的数据库小工具

    一个支持 CodeFirst/DbFirst/ModelFirst 的数据库小工具 Intro DbTool 是一个支持 CodeFirst/DbFirst/ModelFirst 的数据库小工具,原本 ...

  2. [apue] 一个查看当前终端标志位设置的小工具

    话不多说,先看运行效果: >./term input flag 0x00000500 BRKINT not in ICRNL IGNBRK not in IGNCR not in IGNPAR ...

  3. 分享一个 Linux 环境下,强力的Python 小工具

    场景 Linux 用户,经常需要在终端查看一些数据,从文件里看 或者网络协议获取数据并查看. 比如,查看文件里的json数据:比如,查看etcd里存下的数据. 如果直接看cat 或者 curl 得到的 ...

  4. [apue] apue_db:一个可以充当"注册表"的 key-value 数据库

    apue 最后两章都是通过一个完整的实例来解释一些 linux 功能,第20章就是通过一个数据库实例来解释文件锁的使用, 说实话,当时没兴趣,因为满页都是源码和解析,有点看不下去.但是再拾起来硬着头皮 ...

  5. InkImageDataSetGenerator-开源一个可用于机器学习的书写轨迹图片生成的小工具

    这是一个简单易用的图片数据集生成小工具,基于OpenCV和UWP Ink API,它可以根据指定的手写轨迹生成一系列各个角度的图片.每张图片的尺寸和总体数量都是可以指定的,均存放在统一的生成目录中.h ...

  6. EF CodeFirst 创建数据库

    最近悟出来一个道理,在这儿分享给大家:学历代表你的过去,能力代表你的现在,学习代表你的将来. 十年河东十年河西,莫欺少年穷 学无止境,精益求精    话说EF支持三种模式:Code First   M ...

  7. 6.翻译系列:EF 6 Code-First中数据库初始化策略(EF 6 Code-First系列)

    原文链接:http://www.entityframeworktutorial.net/code-first/database-initialization-strategy-in-code-firs ...

  8. 将EF项目从dbfirst转化为codefirst

    一个脚本服务的项目,之前是先设计的数据库表,采用EF的dbfirst做的映射.项目完成后,出现迁移瓶颈. 1.dbfirst项目,如果数据库表结构做了调整,需要重新映射 2.当出现表结构一致,但数据库 ...

  9. python 开发一个支持多用户在线的FTP

    ### 作者介绍:* author:lzl### 博客地址:* http://www.cnblogs.com/lianzhilei/p/5813986.html### 功能实现 作业:开发一个支持多用 ...

随机推荐

  1. KMP Demo

    The key of Kmp is to build a look up table that records the match result of prefix and postfix. Valu ...

  2. 基于unoconv的在线office预览

    这几天在搞在线文档预览,网上查了几种方案, 第一种:使用google的在线预览 -> 国内被Q,pass 第二种:使用第三方的,比如:永中dcs -> 要钱,pass 第三种:先转换为pd ...

  3. echarts4 主题切换

    <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...

  4. ehcache 页面整体缓存和局部缓存

    页面缓存是否有必要?. 这样说吧,几乎所有的网站的首页都是访问率最高的,而首页上的数据来源又是非常广泛的,大多数来自不同的对象,而且有可能来自不同的db ,所以给首页做缓存是很必要的.那么主页的缓存策 ...

  5. day 42 mysql 数据库(2)

    前情提要: 本节继续学习数据库   一:ddl 创建表 >字段名 >数据类型 >约束规则 >显示建表语句 修改表: 二:数据类型 >数值类型 >小数类型 >字 ...

  6. Swift Podfile中的 use_frameworks!

    use_frameworks! A.用cocoapods 导入swift 框架 到 swift项目和OC项目都必须要 use_frameworks!B.使用 dynamic frameworks,必须 ...

  7. LabelRank非重叠社区发现算法介绍及代码实现(A Stabilized Label Propagation Algorithm for Community Detection in Networks)

    最近在研究基于标签传播的社区分类,LabelRank算法基于标签传播和马尔科夫随机游走思路上改装的算法,引用率较高,打算将代码实现,便于加深理解. 这个算法和Label Propagation 算法不 ...

  8. vue 中使用 screenfull.js 全屏插件

    参考网址: https://blog.csdn.net/houyibing930920/article/details/89214200 https://www.jianshu.com/p/cfbb1 ...

  9. eclip 重写从父类继承的方法的快捷操作

    转载自http://blog.sina.com.cn/s/blog_53d599430101phlo.html     一.在代码中单击鼠标右键,在弹出的快捷菜单中选择“源代码(Source)”-&g ...

  10. Windows10下搭建TensorFlow环境

    转载请注明源出处:http://www.cnblogs.com/lighten/p/6753695.html 这篇文章介绍了一下在Windows上安装TensorFlow的步骤,主要是翻译了一下官方的 ...