面向.Net程序员的Sql版本管理
代码版本管理基本上程序员们都知道 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版本管理的更多相关文章
- 读《程序员的SQL金典》[1]--基础数据检索
前言 <程序员的SQL金典>这本书是杨中科老师的,拜读了一下,简单做了读书笔记供以后翻阅.仅供学习分享,要想细读的话推荐购买原版呀! 这次读书的时候用了新的办法把看书计划进行了量化,虽然简 ...
- 面向.Net程序员的后端性能优化实战
最近2个月没做什么新项目 完全是对于旧的系统进行性能优化 避免超时 死锁 数据处理能力不够等常见的性能问题 这里不从架构方面出发 毕竟动大手脚成本比较高 那么我们以实例为前提 从细节开始 优化角度 一 ...
- 面向.Net程序员的前端优化
背景 作为web开发人员大家大多了解一些网站的性能优化方法,其实大部分方法都不复杂,例如针对前端js和css的压缩来减少请求大小,通过合并来减少请求次数.这里站在.Net后端程序员的角度来看一下如何最 ...
- 读《程序员的SQL金典》[4]--SQL调优
一.SQL注入 如果程序中采用sql拼接的方式书写代码,那么很可能存在SQL注入漏洞.避免的方式有两种: 1. 对于用户输入过滤敏感字母: 2. 参数化SQL(推荐). 二.索引 ①索引分类 聚簇索引 ...
- 面向.Net程序员的dump分析
背景 Dump文件是进程的内存镜像.可以把程序的执行状态通过调试器保存到dump文件中.在 Windows 系统上, dump 文件分为内核 dump 和用户态 dump 两种.前者一般用来分析内核相 ...
- 读《程序员的SQL金典》[2]--函数
一.数学函数 1.RAND SELECT RAND () ---0.302870228294199 取0-1之间的随机小数. 2.小数取整 CEILINT(data)舍掉小数部分并向上取整. FLOO ...
- 【程序员的SQL金典】笔记(第6章~第11章)
第六章 索引与约束 1.索引用来提高数据的检索速度,而约束则用来保证数据的完整性. 2.创建索引 创建索引的SQL 语句是CREATE INDEX,其语法如下: CREATE INDE ...
- 【程序员的SQL金典】笔记(第1章~第5章)
第一章数据库入门 1.概念: 数据库 表 列 记录(行) 主键 索引 第二章 数据表的创建和管理 1.数据库系统中的数据类型大致可以分为五类:整数.数值.字符相关.日期时间以及二进 ...
- 读《程序员的SQL金典》[3]--表连接、子查询
一.表连接-JOIN 1. 自连接实例 查询类型相同的订单信息. SELECT O1 .*,O2.* FROM T_Order O1 JOIN T_Order O2 ON O1 .FTypeId= O ...
随机推荐
- Nginx代理与负载均衡配置与优化
Nginx代理 Nginx从0.7.48版本开始,支持了类似Squid的缓存功能.Nginx的Web缓存服务主要由proxy_cache相关指令集和fastcgi_cache相关指令集构成,前者用于反 ...
- GNU libc (Glibc) 2.18 发布
标准C库Glibc发布2.18正式版.2013-08-12 上一个版本是2012-12-25的2.17. 详细改进:Version 2.18 * The following bugs are reso ...
- 个性二维码开源专题<替换元素点>
基础方法:ChangeFillShape //修改填充形状 ChangeFillShape(...) // 摘要: // 修改填充形状 // // 参数: // g: // 图形画板 // // Fo ...
- 使用NHibernate(8)-- 延迟加载
1,延迟加载. 延迟加载,即用到的时候再加载数据.这种机制是非常有情怀的,比如一篇中的用户实体有标签.问题等导航属性,如果只是用到用户名去查询整个实体,则把相关的标签和问题也都加载,性能会比较低.而有 ...
- OWIN的理解和实践(二) – Host和Server的开发
对于开发人员来说,代码就是最好的文档,如上一篇博文所说,下面我们就会基于Kanata项目的一些具体调用代码,来进一步深入理解OWIN的实现和作用. 今天我们先针对Host和Server来实现一个简单的 ...
- Oracle dmp文件导入(还原)到不同的表空间和不同的用户下
------------------------------------- 从生产环境拷贝一个dmp备份文件,在另外一台电脑上搭建测试环境,用imp命令导入dmp文件时提示如下错误: 问题描述: IM ...
- paip.uapi 获取网络url内容html 的方法java php ahk c++ python总结.
paip.uapi 获取网络url内容html 的方法java php ahk c++ python总结. 各种语言总结比较,脚本php.python果然是方便.简短,实用. uapi : get_w ...
- 《Effective STL中文版》前言
<Effective STL中文版>前言 我第一次写关于STL(Standard Template Library,标准模板库)的介绍是在1995 年,当时我在More Effec ...
- javaweb学习总结(八)——HttpServletResponse对象(二)
一.HttpServletResponse常见应用——生成验证码 1.1.生成随机图片用作验证码 生成图片主要用到了一个BufferedImage类,
- (转载)新手如何正确理解GitHub中“PR(pull request)”中的意思
我从知乎看到的两个答案,分别从实际意义以及语言学角度告诉你改怎么理解PR,很简洁,这个理解非常棒,会解决新手刚看到PR(pull request)这个词时的困惑. 实际意义: 有一个仓库,叫R ...