.NET Migration工具

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

Migration是一种分布环境下的数据库同步工具,出现在Ruby on Rail框架里,MigratorDotNet是一个.NET类似于Ruby on Rail的Migrations的数据库版本系统。支持的数据库有MySQL (5.0, 5.1) ,PostgreSQL ,SQLite ,SQL Server (2000, 2005),Oracle (没有经过很好测试),可以通过NantTask,MSBuildTarget, Console Application三种方式来使用。

Migrations的类是Migration的子类,Migration主要有两个方法:Up方法定义这个版本该做什么,Down定义怎么回滚版本.

每一个Migration都应该是数据库中一个非常小的增量修改,常用的尺寸是创建一个表和给表增加一个字段或者多个字段,修改表的数据和对表执行一个ExecuteQuery自定义查询。保持Migration的尽量小,这样方便在版本之间的迁移,就在版本控制系统SVN,TFS那样,Migration的例子是这样的:

// Version 1
[Migration(1)]
public class CreateUserTable : Migration
{
public void Up()
{
Database.CreateTable("User",
new Column("UserId", DBType.Int32, ColumnProperties.PrimaryKeyWithIdentity),
new Column("Username", DBType.AnsiString, 25)
);
}
public void Down()
{
Database.RemoveTable("User");
}
}

Migration属性使用一个整数来表示,代表当前的数据库版本,工具就是通过这个属性来决定数据库之间的迁移。你如果使用控制台程序,版本号作为参数传给控制台程序,当然你也可以使用NAnt脚本或者MSBuild脚本。

下面是一段NAnt编译脚本:

<?xml version="1.0" ?>

<project default="migrate">

         <property name="project.dir" value="."/>

         <property name="output.dir" value="${project.dir}\Output" />

   <loadtasks assembly="${project.dir}\lib\migrator\Migrator.NAnt.dll" />



         <target name="clean" description="Deletes the previously built directories">

                 <delete dir="${output.dir}" failonerror="false" />

         </target>



         <target name="build" description="Builds Migration Project" depends="clean">

                 <msbuild project="${project.dir}\src\Migrations.Project\Migrations.Project.csproj">

                         <property name="Configuration" value="Debug" />

                         <property name="OutDir" value="${output.dir}\\" />

                 </msbuild>

         </target>

         

         <!-- Database Migrations task -->

   <target name="migrate" description="Migrate the database" depends="build">

     <!-- Using a version of -1 will cause the migration to migrate to the latest version -->

     <property name="version" value="-1" overwrite="false" />

     <migrate

       provider="MySql"

       connectionstring="Database=mydb;Data Source=localhost;User Id=mysqluser;Password=mysqlpassword;"

       migrations="${output.dir}\Migrations.Project.dll"

       to="${version}" />

   </target>

</project>

本文来自云栖社区合作伙伴“doNET跨平台”,了解相关信息可以关注“opendotnet”微信公众号

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
16天前
|
数据可视化 开发工具 C#
.NET开源、免费、跨平台的Git可视化管理工具
俗话说得好“工欲善其事,必先利其器”,合理的选择和使用可视化的管理工具可以降低技术入门和使用的门槛。今天大姚给大家分享一款.NET Avalonia开源、免费、跨平台、快速的Git可视化管理工具:SourceGit。
|
1月前
|
安全 数据安全/隐私保护 开发者
三款.NET 代码混淆工具比较分析:ConfuserEx、Obfuscar 和 Ipa Guard
三款.NET 代码混淆工具比较分析:ConfuserEx、Obfuscar 和 Ipa Guard
|
4月前
|
JSON IDE 前端开发
[.NET开发者的福音]一个方便易用的在线.NET代码编辑工具.NET Fiddle
[.NET开发者的福音]一个方便易用的在线.NET代码编辑工具.NET Fiddle
|
6月前
|
存储 开发者
使用.NET设计一个Epub电子书生成工具
Novel Epub Maker 是一个用于制作小说 epub 电子书的 .NET 类库。它不依赖任何第三方库,轻巧使用方便,可以快速适用于小说制作 ebup 和 txt 转 epub 等场景。
55 0
|
7月前
|
存储 C# 数据库
.NET开源的在Windows上统计软件使用时长和网站浏览时长工具 - Tai
.NET开源的在Windows上统计软件使用时长和网站浏览时长工具 - Tai
|
API
.net core工具组件系列之Autofac—— 第二篇:Autofac的3种依赖注入方式(构造函数注入、属性注入和方法注入),以及在过滤器里面实现依赖注入
本篇文章接前一篇,建议可以先看前篇文章,再看本文,会有更好的效果。前一篇跳转链接:https://www.cnblogs.com/weskynet/p/15046999.html
411 0
.net core工具组件系列之Autofac—— 第二篇:Autofac的3种依赖注入方式(构造函数注入、属性注入和方法注入),以及在过滤器里面实现依赖注入
|
7月前
|
开发框架 C#
.NET开源的小巧、美观的桌面快速启动工具
.NET开源的小巧、美观的桌面快速启动工具
|
3月前
|
开发框架 算法 .NET
新手友好、轻量级的C#/.NET万能工具库
新手友好、轻量级的C#/.NET万能工具库
|
4月前
|
C# 数据安全/隐私保护
一款实用的.NET Core加密解密工具类库
一款实用的.NET Core加密解密工具类库
|
4月前
|
缓存 C# Windows
一款.NET开源的小巧、智能、免费的Windows内存清理工具 - WinMemoryCleaner
一款.NET开源的小巧、智能、免费的Windows内存清理工具 - WinMemoryCleaner