代码版本管理基本上程序员们都知道 TFS GIT SVN等等 但是对于数据库版本管理 java程序员或许会了解一些 但是.Net程序员收获的资料应该不多。

特别是现在云概念使用越来越广的情况下,与应用程序开发和部署常规管理数据库更改在一起便成为一个难题。

这里就分享一个用来进行sql版本管理的.net程序。源码地址:https://github.com/dubing/SqlMigrator


如图所示

因为只是研究着玩 暂时工具做的不复杂 提供版本跟进 回滚等基本功能

FluentMigrator : https://github.com/schambers/fluentmigrator/wiki/Migration

基于开源组件FluentMigrator通过nuget可以很方便的获取

我们通过一个工程来专门定义管理数据库版本。

下面我们一步一步来研究

首先最基本的是建表

这里我们创建了一个user是表并且附带2个字段其中id是主键并且自增,name为一个string类型不可空并且默认值为Anonymous。

通过程序我们发现对于一次部署或者迁移我们会重写2块代码 一个是up()一个是down()通过字面意思我们就可以理解到 他们分别实现的功能是向上迁移和向下回滚。

[Migration(2015031201)]中的2015031201即为我们的版本号,需要以数字组成,使用日期的方式+自定义版本号是个很好的选择。

类名相当于描述,起着备注说明的作用。

FluentMigrator运行的方式有很多种,可以通过命令行,Nant,msbuild,Rake等等。demo程序中结合winform使用命令行方式执行。

我们先来看一下我们操作的效果,

本来我们所连的数据库是没有users这张表的

我们运行一下程序 执行版本跟进

执行成功,重新加载看看

已经有版本信息里,最后我们到数据库确认一下

其实除了我们编写的部分,FluentMigrator也会在我们的数据库中新生成一张表versioninfo用来记录我们的版本信息,来保证我们不会进行多余和重复的跟进或者回滚。

下面我们来继续创建第2个部署模块

运行demo

我们会发现程序自动略过了2015031201,重新加载数据库

当前版本已经为新的 并且添加了履历。数据库也是添加成功


上面我们一直讨论版本跟进 下面我们来尝试下回滚,接着上面的demo,这个时候我们已经进行了2次部署,如果我发现最新的一次不是我想要的 我需要回滚到上面一个版本。

那么我们点击回滚到上一次看一下

我们发现我们运行的命令不同了。同时我们的版本信息回到了上一次。


如果说我对FluentMigrator本身的语法并不了解怎么办,没关系。FluentMigrator本身支持sql脚本。

运行demo

细心的同学会发现 2015031202也被我们执行了 因为对于FluentMigrator而言 如果你本身回滚后不做任何处理,当下一次版本跟进的时候它会认为那次部署还是有效的。如果要T掉那个部署可以选择在项目中注释掉或者移除那个部署模块。

如此看来 我们基本的版本管理动作是ok的。那么除了创建和删除表,我们还可以进行大部分sql操作,例如更新列,添加数据,更改表名称等等。下面我们简单来试验一下。

         /// <summary>
///添加列
/// </summary>
[Migration()]
public class AlertUser : Migration
{
public override void Up()
{
Alter.Table("Users")
.AddColumn("Age")
.AsInt16()
.Nullable();
} public override void Down()
{
Delete.Column("Age").FromTable("Users");
}
} /// <summary>
/// 添加行数据
/// </summary>
[Migration()]
public class AddDeptRows : Migration
{
public override void Up()
{
Insert.IntoTable("Dept").Row(new { DeptName = "maoyatest" });
} public override void Down()
{
Delete.FromTable("Dept").Row(new { DeptName = "maoyatest" });
}
} /// <summary>
/// 修改表名称
/// </summary>
[Migration()]
public class RenameUsers : Migration
{
public override void Up()
{
Rename.Table("Users").To("UsersNew");
} public override void Down()
{
Rename.Table("UsersNew").To("Users");
}
}

看运行结果

重新加载

版本信息也正确

结果也是完全正确。


本篇先到此 希望对大家有帮助 下篇会分享下redis的玩法

面向.Net程序员的Sql版本管理的更多相关文章

  1. 读《程序员的SQL金典》[1]--基础数据检索

    前言 <程序员的SQL金典>这本书是杨中科老师的,拜读了一下,简单做了读书笔记供以后翻阅.仅供学习分享,要想细读的话推荐购买原版呀! 这次读书的时候用了新的办法把看书计划进行了量化,虽然简 ...

  2. 面向.Net程序员的后端性能优化实战

    最近2个月没做什么新项目 完全是对于旧的系统进行性能优化 避免超时 死锁 数据处理能力不够等常见的性能问题 这里不从架构方面出发 毕竟动大手脚成本比较高 那么我们以实例为前提 从细节开始 优化角度 一 ...

  3. 面向.Net程序员的前端优化

    背景 作为web开发人员大家大多了解一些网站的性能优化方法,其实大部分方法都不复杂,例如针对前端js和css的压缩来减少请求大小,通过合并来减少请求次数.这里站在.Net后端程序员的角度来看一下如何最 ...

  4. 读《程序员的SQL金典》[4]--SQL调优

    一.SQL注入 如果程序中采用sql拼接的方式书写代码,那么很可能存在SQL注入漏洞.避免的方式有两种: 1. 对于用户输入过滤敏感字母: 2. 参数化SQL(推荐). 二.索引 ①索引分类 聚簇索引 ...

  5. 面向.Net程序员的dump分析

    背景 Dump文件是进程的内存镜像.可以把程序的执行状态通过调试器保存到dump文件中.在 Windows 系统上, dump 文件分为内核 dump 和用户态 dump 两种.前者一般用来分析内核相 ...

  6. 读《程序员的SQL金典》[2]--函数

    一.数学函数 1.RAND SELECT RAND () ---0.302870228294199 取0-1之间的随机小数. 2.小数取整 CEILINT(data)舍掉小数部分并向上取整. FLOO ...

  7. 【程序员的SQL金典】笔记(第6章~第11章)

        第六章 索引与约束   1.索引用来提高数据的检索速度,而约束则用来保证数据的完整性.   2.创建索引 创建索引的SQL 语句是CREATE INDEX,其语法如下: CREATE INDE ...

  8. 【程序员的SQL金典】笔记(第1章~第5章)

      第一章数据库入门 1.概念: 数据库 表 列 记录(行) 主键 索引         第二章 数据表的创建和管理 1.数据库系统中的数据类型大致可以分为五类:整数.数值.字符相关.日期时间以及二进 ...

  9. 读《程序员的SQL金典》[3]--表连接、子查询

    一.表连接-JOIN 1. 自连接实例 查询类型相同的订单信息. SELECT O1 .*,O2.* FROM T_Order O1 JOIN T_Order O2 ON O1 .FTypeId= O ...

随机推荐

  1. glRotate函数

    void glRotate( GLdouble angle, GLdouble x, GLdouble y, GLdouble z ) API说明:angle为旋转角度,单位为度:x,y,z是旋转轴的 ...

  2. codeforces 427E

    题意:给定一位空间里n个点的坐标,每个坐标有一个罪犯,现在要建一个警局,并且这个警局只有一辆车,车一次最多载m个人,问应建在哪是的抓回所有罪犯的路程和最小. 思路: 很明显建在罪犯的点上一定可以找到最 ...

  3. halcon摄像机标定

    摄像机标定程序: 注意:E:/calibration_image :为标定图像文件路径       'E:/calibration_description/caltab_123mm.descr:为标定 ...

  4. [leetcode 19] Remove Nth Node From End of List

    1 题目 Given a linked list, remove the nth node from the end of list and return its head. For example, ...

  5. Asp.Net Web API 2第三课——.NET客户端调用Web API

    详情请查看http://aehyok.com/Blog/Detail/70.html 个人网站地址:aehyok.com QQ 技术群号:206058845,验证码为:aehyok 本文文章链接:ht ...

  6. Python的with语句

    写过多线程程序的人肯定对各种锁很熟悉,尤其是下面这种代码 def lock_usage: lock.Lock() if(...) : lock.Unlock() return lock.Unlock( ...

  7. C语言 串 顺序结构 实现

    一个能够自动扩容的顺序结构的串 ArrString (GCC编译). /** * @brief C语言 串 顺序结构 实现 * @author wid * @date 2013-11-01 * * @ ...

  8. node-webkit教程(11)Platform Service之shell

    node-webkit教程(11)Platform Service之shell 文/玄魂 目录 node-webkit教程(10)Platform Service之shell 前言 11.1  She ...

  9. 分享我用Qt开发的应用程序【二】在Qt应用程序中使用字体图标fontawesome

    为了使用简单,需要先写一个单件类,头文件的代码如下: 其中静态方法Instance保证IconHelper的实例全局唯一 (注意构造函数已经私有化了) #ifndefICONHELPER_H #def ...

  10. 实验五 含有控制信号的计数器VHDL设计

    一.实验目的 学习计数器的设计.仿真和硬件测试,进一步熟悉VHDL设计技术. 二.实验仪器与器材 计算机1台,GW48-PK2S实验箱1台,QuartusⅡ6.0 1套. 三.实验 1. 基本命题 在 ...