开源的 .NET 数据库迁移框架

23213c06b4e92d438824169c1a19f0b2.png

4124bfef16214933537ad2690491282f.gif

d2ef2df04e5325c8d98dddd6cb199379.png

你好,这里是 Dotnet 工具箱,定期分享 Dotnet 有趣,实用的工具和组件,希望对您有用!

简介

FluentMigrator 是一个开源的数据库迁移框架,可以帮助用户在开发过程中保持数据库的一致性。它提供了一个简洁的 Fluent API,可以让你使用 C# 写出简洁的迁移脚本。FluentMigrator 提供了一系列的 API 用来创建和管理数据库迁移,并且支持多种不同的数据库系统,包括 MySQL、PostgreSQL 和 SQL Server 等。

使用 FluentMigrator 可以轻松地管理数据库迁移,这对于敏捷开发项目特别有用。比如,当开发团队的成员对数据库做出更改时,FluentMigrator 可以自动检测并应用这些更改,从而确保数据库保持一致性。

如何使用

下面是一个示例,展示了如何在 .NET 中使用 FluentMigrator。

首先,创建一个控制台项目。

dotnet new console --name test

添加以下 Nuget 包, 这里我们使用了 SQLite 数据库。

dotnet add package FluentMigratordotnet add package FluentMigrator.Runnerdotnet add package FluentMigrator.Runner.SQLitedotnet add package Microsoft.Data.Sqlite

使用下面的代码创建一个迁移类,20220430_AddLogTable.cs, 这里我们使用了 Migration 特性指定了版本。

using FluentMigrator;namespace test
{[Migration(20220430121800)]public class AddLogTable : Migration{public override void Up(){Create.Table("Log").WithColumn("Id").AsInt64().PrimaryKey().Identity().WithColumn("Text").AsString();}public override void Down(){Delete.Table("Log");}}
}

这将会创建 Log 表和 ID , Text 列。

准备好迁移类后, 使用下面的代码,运行我们的迁移。

using System;
using System.Linq;using FluentMigrator.Runner;
using FluentMigrator.Runner.Initialization;using Microsoft.Extensions.DependencyInjection;namespace test
{class Program{static void Main(string[] args){var serviceProvider = CreateServices(); using (var scope = serviceProvider.CreateScope()){UpdateDatabase(scope.ServiceProvider);}}private static IServiceProvider CreateServices(){return new ServiceCollection() .AddFluentMigratorCore().ConfigureRunner(rb => rb .AddSQLite() .WithGlobalConnectionString("Data Source=test.db") .ScanIn(typeof(AddLogTable).Assembly).For.Migrations()) .AddLogging(lb => lb.AddFluentMigratorConsole()) .BuildServiceProvider(false);}private static void UpdateDatabase(IServiceProvider serviceProvider){ var runner = serviceProvider.GetRequiredService<IMigrationRunner>(); runner.MigrateUp();}}
}

运行上面的代码,程序会自动运行迁移,创建指定的 Log 表。

在进行多版本的更新后, 如何进行回滚呢,你可能已经注意到了, 上面的代码中我们实现 Down 方法, 删除了 Log 表。它表示,如果我们回滚到 Migration(20220430121800) 这个版本时,它会执行 Down 方法并删除 Log 表。

FluentMigrator 的主要优点在于它的易用性和灵活性。它的语法简洁明了,能够让开发人员快速编写数据库迁移脚本。此外,FluentMigrator 还支持在迁移过程中执行多种操作,包括创建表、添加字段、修改表结构等。

总之,FluentMigrator 是一款优秀的数据库迁移工具,能够为开发人员提供简洁、灵活的方式来管理数据库迁移。

项目地址

https://github.com/fluentmigrator/fluentmigrator

178369f10b7a374e6c7eca33b62d0cc5.jpeg

Dotnet 工具箱

扫码关注我们

a6443606942918f09634d4700a4b000b.png

分享

c17cc55532da328b3664d4a74a573df2.png

点收藏

71d542bb51833dcb7f477b8b787616dd.png

点点赞

e8dd69a48b61985be9263157a4d9c852.png

点在看

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/280325.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2015年IT领域里Docker和其它颠覆性的趋势

本文讲的是2015年IT领域里Docker和其它颠覆性的趋势&#xff0c;【编者的话】文中作者介绍了2015年IT领域的一些颠覆性的趋势&#xff0c;比如Docker将如何革新PaaS、IaaS等&#xff0c;Docker将如何颠覆虚拟化、私有云、配置管理。 2014年真是令人兴奋的一年&#xff0c;这一年…

进化:从孤胆极客到高效团队_极客狂:为什么这么多的网站无法使用打印样式表?...

进化:从孤胆极客到高效团队It never ceases to amaze me that people have to look for a link or a button that says “Print” on a web page, especially considering there’s a miracle technology that makes that step unnecessary. Sadly almost nobody uses it, even…

apple tv 开发_如何跨多台Apple TV同步Apple TV的主屏幕

apple tv 开发If you have more than one Apple TV in your household, you probably know how annoying it is when you have to install Apple TV apps multiple times on each device. However, with the release of tvOS 11, that’s no longer the case. 如果您的家庭中有…

这些故事说的都是你——译者带你读《硅谷革命》

作者 | 薛命灯 作为《硅谷革命》的译者之一&#xff0c;同时也是一个拥有十余年软件开发和架构经验的工程师&#xff0c;当时我在决定是否接受重译这本书的时候&#xff0c;几乎是不假思索地答应了郭蕾&#xff08;本书重启版发起人之一&#xff09;的提议&#xff0c;只因他的…

runc容器逃逸漏洞最强后续:应对之策汇总与热点疑问解答

美国时间2019年2月11日晚&#xff0c;runc通过oss-security邮件列表披露了runc容器逃逸漏洞CVE-2019-5736的详情。runc是Docker、CRI-O、Containerd、Kubernetes等底层的容器运行时&#xff0c;此次安全漏洞无可避免地会影响大多数Docker与Kubernetes用户&#xff0c;也因此为整…

com surrogate_什么是“ COM Surrogate”(dllhost.exe),为什么它在我的PC上运行?

com surrogateIf you poke around in your Task Manager, there’s a good chance you’ll see one or more “COM Surrogate” processes running on a Windows PC. These processes have the file name “dllhost.exe”, and are part of the Windows operating system. You’…

facebook 邀请好友_如何查看紧急情况下您的Facebook朋友是否安全

facebook 邀请好友Facebook’s Safety Check feature lets you check in during an emergency to confirm you’re safe. If you have friends or family in an area that you haven’t heard from, though, you may want to ask them directly. Here’s how to ask someone to…

【您有一封来自阿里云的邀请函】阿里云成都客户服务中心20+职位虚席以待,来吧,成就最好的自己!...

如果你不想辜负这个科技的时代&#xff0c;相信它会因你而不同。如果你不想仅做年度大戏的观众&#xff0c;相信自己会成为主角。如果你不想淹没在枯燥与苟且中&#xff0c;相信工作有诗和远方。那么&#xff0c;不要犹豫&#xff0c;加入我们&#xff01;在这&#xff0c;你已…

.NET 代码优化 聊聊逻辑圈复杂度

本文属于 dotnet 代码优化系列博客。相信大家都对圈复杂度这个概念很是熟悉&#xff0c;本文来和大家聊聊逻辑的圈复杂度。代码优化里面&#xff0c;一个关注的重点在于代码的逻辑复杂度。一段代码的逻辑复杂度越高&#xff0c;那么维护起来的难度也就越大。衡量代码的逻辑复杂…

GO语言基础条件、跳转、Array和Slice

1. 判断语句if 1. 条件表达式没有括号&#xff08;这点其他语言转过来的需要注意&#xff09; 2. 支持一个初始化表达式&#xff08;可以是并行方式&#xff0c;即&#xff1a;a, b, c : 1, 2, 3) 3. 左大括号必须和条件语句或 else 在同一行 4. 支持单行模式 5. 初始化语句中的…

干式真空泵原理_如何安装干式墙锚在墙壁上悬挂重物

干式真空泵原理If you ever plan to mount something to the wall that’s even remotely heavy, you’ll need to use drywall anchors if a stud isn’t available. Here are the different types of drywall anchors, and how to use each one. 如果您打算将甚至更重的东西安…

sharding-jdbc学习

sharding-jdbc的全局id生成策略是通过雪花算法来实现的。 sharding-jdbc也是一个数据的中间件&#xff0c;可实现读写分离和分库分表&#xff0c;比mycat要简单些。 nginx与ribbon实现负载均衡的区别&#xff1a;nginx是实现服务器端的负载均衡&#xff0c;ribbon是实现客户端即…

像go 一样 打造.NET 单文件应用程序的编译器项目bflat 发布 7.0版本

现代.NET和C#在低级/系统程序以及与C/C/Rust等互操作方面的能力完全令各位刮目相看了&#xff0c;有人用C#开发的64位操作系统: GitHub - nifanfa/MOOS: C# x64 operating system pro...&#xff0c;截图要介绍的是一个结合Roslyn和NativeAOT的实验性编译器bflat &#xff1a;h…

添加dubbo.xsd的方法

整合dubbo-spring的时候&#xff0c;配置文件会报错 因为 阿里关闭在线的域名了.需要本地下载xsd文件 所以&#xff0c;需要下载本地引入。 解决方式&#xff1a; 在dubbo的开源项目上找到xsd文件&#xff1a; https://github.com/alibaba/dubbo Idea使用本地xsd Setting…

Spring Cloud Feign注意点

2019独角兽企业重金招聘Python工程师标准>>> 1、只要在启动类中加入EnableFeignClients注解&#xff0c;才会扫描FeignClient注解 2、Feign主要是通过接口调用&#xff0c;底层其实也是HttpClient/OkHttp 1&#xff09;提供一个Feign接口&#xff0c;加入对应的rest…

word 替换 增加引号_如何在Word 2013文档中替换部分(不是全部)智能引号

word 替换 增加引号Word includes a setting that allows you to automatically convert straight quotes to smart quotes, or specially curved quotes, as you type. However, there may be times you need straight quotes and you may have to convert some of the quotes…

i-i.me:网址导航真的是伪需求吗?

每一个程序员都有一个框架梦&#xff0c;每一个站长曾经都有一个网址导航梦。本人从07年开始接触互联网&#xff0c;成为一名中国草根站长&#xff0c;到现在终于熬成半个程序员。10年时间&#xff0c;没有赚到钱&#xff0c;也没有练就一身过硬的技术&#xff08;所以叫半个程…

.Net AOT--Win11搭建和编译 X64 汇编

楔子&#xff1a;windows11上编译x64汇编&#xff0c;很多人不太了解。甚至搞出DOSBox这种几亿年前的老古董&#xff0c;还有的专门搞些Linux下面的工具来搞到Windows上运行。其实这些大可不必&#xff0c;也没这么麻烦。微软技术出身&#xff0c;基本上工具链齐全。本篇来看下…

安装mongoDB遇见的一个路径问题

如果安装路径不存在&#xff0c;则不会解压EXE软件&#xff01; 安装monogoDB后&#xff0c;它不会自动添加执行路径&#xff01; 意思就是安装路径是D盘下面的mongoDB文件夹&#xff0c;假如不存在这个文件夹&#xff0c;则不会安装成功 你需要添加路径&#xff1a; 你可以利用…

【Filecoin源码仓库全解析】第一章:搭建Filecoin测试节点

2019.2.14 情人节&#xff0c;Filecoin项目开放了核心源码仓库go-filecoin&#xff0c;并更新了 filecoin-project organization下的诸多核心成果&#xff0c;这意味着&#xff0c;Filecoin已然度过了最困难的难点攻关期&#xff0c;进入到了全民公测阶段。 本系列文章将协助大…