Flyway数据库版本控制的教程详解

作者:CALLME熊大 时间:2024-01-19 03:10:03 

前言:

最近工作上遇到个问题,项目开发过程中,开发代码可以通过svn来版本控制,但数据库又该如何来管理呢?多个人接触数据库,当对表、字段或数据修改后,又怎么来同步呢?经过苦寻,发现了个叫flyway的开源项目:http://flywaydb.org/ ,java编写,官方的介绍就是我的初衷,岂能不心动?

官网是英文的,查了下居然没有中文文档,难道没有中国人用?

慢慢看了下官方文档,试着做了下,一次成功!(离开电脑,蹦达几下,继续坐回电脑)

自己写个小教程吧

1、将flyway-core-2.3.jar放到项目lib中,下载地址:http://flywaydb.org/getstarted/download.html

2、在src目录下建立保存sql版本文件的路径:src/db/migration,flyway默认查找路径,可以改,但没必要。


Flyway数据库版本控制的教程详解

3、在sql版本文件路径中增加sql文件,命名规则,如:V1__2014_4_13.sql ,V开头+版本号+双下划线+描述,描述中可以有下划线,后缀为sql。别问能不能修改这个规则,否则,我咬你。

4、增加flyway的java类,有命令行工具,但还是java类用起来方便,如下:


package com.cms.flyway;

import java.io.IOException;
import java.util.Properties;

import com.googlecode.flyway.core.Flyway;

public class FlywayApp {

// 读取数据库配置参数
private static Properties config = new Properties();
static {
 try {
  config.load(Thread.currentThread().getContextClassLoader().getResourceAsStream("activerecord.properties"));
 } catch (IOException e) {
  e.printStackTrace();
 }
}

// 执行数据库版本升级
public static void migration() {
 // Create the Flyway instance
 Flyway flyway = new Flyway();

// Point it to the database
 flyway.setDataSource(config.getProperty("com.et.ar.ActiveRecordBase.url"), config.getProperty("com.et.ar.ActiveRecordBase.username"), config.getProperty("com.et.ar.ActiveRecordBase.password"));
 flyway.setInitOnMigrate(true);

// Start the migration
 flyway.migrate();
}
}

5、在服务器启动的时候或者定时器 执行该类的migration()方法即可。

6、第一次执行会生成一个专门存放数据库schema_version的表


Flyway数据库版本控制的教程详解

7、以后数据库有了新的改动,导出新版本sql文件(如:mysqldump -u -p databasename>/xx.sql)改为新版本命名文件放到db.migration路径下,flyway会自动帮你更新数据库版本的。

总结

标签:Flyway,数据库,版本控制
0
投稿

猜你喜欢

  • eslint常见的一些报错及解决方法

    2024-05-11 09:09:32
  • Linux mysql安装修改root密码服务

    2010-10-14 13:59:00
  • Python-OpenCV实现图像缺陷检测的实例

    2023-02-16 19:38:46
  • MS SQL SERVER 数据库日志压缩方法与代码

    2024-01-13 04:24:00
  • asp实现非大小写的替换函数

    2010-05-19 21:23:00
  • python实现桌面气泡提示功能

    2023-07-13 06:37:13
  • Mootools 1.2教程(10)——Fx.Tween的使用

    2008-12-02 18:03:00
  • 关于python下cv.waitKey无响应的原因及解决方法

    2022-03-04 14:51:21
  • Python中的闭包总结

    2023-09-09 03:46:05
  • python网络爬虫实战

    2021-04-16 13:31:07
  • Python 读取图片文件为矩阵和保存矩阵为图片的方法

    2022-07-23 05:21:11
  • perl的格式化(Format)报表输出实现代码

    2022-02-10 09:43:47
  • Django中的FBV和CBV用法详解

    2023-09-15 10:41:06
  • vue.js 自定义指令(拖拽、拖动、移动) 指令 v-drag详解

    2024-05-28 15:55:24
  • 网页HTTP header头信息详解

    2010-03-31 14:42:00
  • 对django中foreignkey的简单使用详解

    2021-09-04 21:04:20
  • js下用eval生成JSON对象

    2024-04-19 10:00:24
  • 巧用正则表达式获取新闻中图片地址

    2010-07-17 13:09:00
  • 实用又漂亮的BootstrapValidator表单验证插件

    2024-05-09 10:39:52
  • Python random模块制作简易的四位数验证码

    2023-06-29 07:41:50
  • asp之家 网络编程 m.aspxhome.com