前言:
最近工作上遇到個(gè)問(wèn)題,項(xiàng)目開(kāi)發(fā)過(guò)程中,開(kāi)發(fā)代碼可以通過(guò)svn來(lái)版本控制,但數(shù)據(jù)庫(kù)又該如何來(lái)管理呢?多個(gè)人接觸數(shù)據(jù)庫(kù),當(dāng)對(duì)表、字段或數(shù)據(jù)修改后,又怎么來(lái)同步呢?經(jīng)過(guò)苦尋,發(fā)現(xiàn)了個(gè)叫flyway的開(kāi)源項(xiàng)目:http://flywaydb.org/ ,java編寫(xiě),官方的介紹就是我的初衷,豈能不心動(dòng)?
官網(wǎng)是英文的,查了下居然沒(méi)有中文文檔,難道沒(méi)有中國(guó)人用?
慢慢看了下官方文檔,試著做了下,一次成功?。x開(kāi)電腦,蹦達(dá)幾下,繼續(xù)坐回電腦)
自己寫(xiě)個(gè)小教程吧
1、將flyway-core-2.3.jar放到項(xiàng)目lib中,下載地址:http://flywaydb.org/getstarted/download.html
2、在src目錄下建立保存sql版本文件的路徑:src/db/migration,flyway默認(rèn)查找路徑,可以改,但沒(méi)必要。
3、在sql版本文件路徑中增加sql文件,命名規(guī)則,如:V1__2014_4_13.sql ,V開(kāi)頭+版本號(hào)+雙下劃線+描述,描述中可以有下劃線,后綴為sql。別問(wèn)能不能修改這個(gè)規(guī)則,否則,我咬你。
4、增加flyway的java類,有命令行工具,但還是java類用起來(lái)方便,如下:
package com.cms.flyway; import java.io.IOException; import java.util.Properties; import com.googlecode.flyway.core.Flyway; public class FlywayApp { // 讀取數(shù)據(jù)庫(kù)配置參數(shù) private static Properties config = new Properties(); static { try { config.load(Thread.currentThread().getContextClassLoader().getResourceAsStream("activerecord.properties")); } catch (IOException e) { e.printStackTrace(); } } // 執(zhí)行數(shù)據(jù)庫(kù)版本升級(jí) 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、在服務(wù)器啟動(dòng)的時(shí)候或者定時(shí)器 執(zhí)行該類的migration()方法即可。
6、第一次執(zhí)行會(huì)生成一個(gè)專門存放數(shù)據(jù)庫(kù)schema_version的表
7、以后數(shù)據(jù)庫(kù)有了新的改動(dòng),導(dǎo)出新版本sql文件(如:mysqldump -u -p databasename>/xx.sql)改為新版本命名文件放到db.migration路徑下,flyway會(huì)自動(dòng)幫你更新數(shù)據(jù)庫(kù)版本的。
總結(jié)
到此這篇關(guān)于Flyway數(shù)據(jù)庫(kù)版本控制的教程詳解的文章就介紹到這了,更多相關(guān)Flyway數(shù)據(jù)庫(kù)版本控制內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
標(biāo)簽:桂林 南昌 東莞 黔南 宣城 文山 鹽城 景德鎮(zhèn)
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Flyway數(shù)據(jù)庫(kù)版本控制的教程詳解》,本文關(guān)鍵詞 Flyway,數(shù)據(jù)庫(kù),版本,控制,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。