本文整理匯總了Java中org.flywaydb.core.Flyway.migrate方法的典型用法代碼示例。如果您正苦於以下問題:Java Flyway.migrate方法的具體用法?Java Flyway.migrate怎麽用?Java Flyway.migrate使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類org.flywaydb.core.Flyway
的用法示例。
在下文中一共展示了Flyway.migrate方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: initFlyway
import org.flywaydb.core.Flyway; //導入方法依賴的package包/類
/**
* Initialise Flyway
*
* @param ds
*/
private void initFlyway(DataSource ds) {
try {
logger.info("Database analysis: in progress...");
Flyway flyway = new Flyway();
flyway.setDataSource(ds);
flyway.setCallbacks(new FlywayCallbackMigration());
flyway.setBaselineOnMigrate(true);
flyway.setValidateOnMigrate(true);
flyway.repair();
flyway.migrate();
logger.info("Database analysis: finish...");
} catch (Exception e) {
logger.error("Database analysis: ERROR", e);
throw e;
}
}
示例2: migrateOrCreateIfNotExists
import org.flywaydb.core.Flyway; //導入方法依賴的package包/類
public static boolean migrateOrCreateIfNotExists(String dbname) {
String dbpath = getDbPath(dbname);
String jdbcurl = "jdbc:h2:file:" + dbpath + ";DB_CLOSE_ON_EXIT=FALSE";
LOG.info("new jdbcurl = {}", jdbcurl);
Connection conn = null;
try {
conn = DriverManager.getConnection(jdbcurl, "sa", "");
DataSource ds = new CustomFlywayDataSource(new PrintWriter(System.out), conn);
Flyway flyway = new Flyway();
flyway.setDataSource(ds);
// explicitly set h2db driver loaded (= including this jar file) class loader
flyway.setClassLoader(conn.getClass().getClassLoader());
flyway.migrate();
LOG.info("db[{}] migration success", dbname);
// may be already closed -> reconnect.
DbUtils.closeQuietly(conn);
conn = DriverManager.getConnection(jdbcurl, "sa", "");
QueryRunner r = new QueryRunner();
Long cnt = r.query(conn, "select count(*) from PROXY_HISTORY", new ScalarHandler<Long>());
LOG.info("db[{}] open/creation success(select count(*) from logtable returns {})", dbname, cnt);
return true;
} catch (SQLException e) {
LOG.error("db[" + dbname + "] open/migrate/creation error", e);
return false;
} finally {
DbUtils.closeQuietly(conn);
}
}
示例3: migrateFlyway
import org.flywaydb.core.Flyway; //導入方法依賴的package包/類
@PostConstruct
public void migrateFlyway() {
Flyway flyway = new Flyway();
if (this.nakadiProducerFlywayDataSource != null) {
flyway.setDataSource(nakadiProducerFlywayDataSource);
} else if (this.flywayProperties.isCreateDataSource()) {
flyway.setDataSource(this.flywayProperties.getUrl(), this.flywayProperties.getUser(),
this.flywayProperties.getPassword(),
this.flywayProperties.getInitSqls().toArray(new String[0]));
} else if (this.flywayDataSource != null) {
flyway.setDataSource(this.flywayDataSource);
} else {
flyway.setDataSource(dataSource);
}
flyway.setLocations("classpath:db_nakadiproducer/migrations");
flyway.setSchemas("nakadi_events");
if (callback != null) {
flyway.setCallbacks(callback);
}
flyway.setBaselineOnMigrate(true);
flyway.setBaselineVersionAsString("2133546886.1.0");
flyway.migrate();
}
示例4: updateDatabase
import org.flywaydb.core.Flyway; //導入方法依賴的package包/類
@PostConstruct
public void updateDatabase() throws IOException {
try {
Flyway flyway = new Flyway();
flyway.setEncoding("UTF-8");
flyway.setTable("flyway_schema");
flyway.setLocations("db/migration");
flyway.setSchemas(env.getProperty(PropertyNames.jdbcUser));
flyway.setDataSource(
env.getProperty(PropertyNames.jdbcURL),
env.getProperty(PropertyNames.flywayUser),
env.getProperty(PropertyNames.flywayPassword));
flyway.setBaselineOnMigrate(true);
flyway.migrate();
} catch (Exception e) {
log.error("FAILED TO MIGRATE DATABASE", e);
}
}
示例5: getConnection
import org.flywaydb.core.Flyway; //導入方法依賴的package包/類
public static Connection getConnection(String dbname) throws SQLException {
String dbpath = getDbPath(dbname);
String jdbcurl = "jdbc:h2:file:" + dbpath + ";DB_CLOSE_ON_EXIT=FALSE";
LOG.info("connect jdbcurl = {}", jdbcurl);
Connection conn = DriverManager.getConnection(jdbcurl, "sa", "");
DataSource ds = new CustomFlywayDataSource(new PrintWriter(System.out), conn);
Flyway flyway = new Flyway();
flyway.setDataSource(ds);
// explicitly set h2db driver loaded (= including this jar file) class loader
flyway.setClassLoader(conn.getClass().getClassLoader());
flyway.migrate();
LOG.info("db[{}] migration success", dbname);
// may be already closed -> reconnect.
DbUtils.closeQuietly(conn);
conn = DriverManager.getConnection(jdbcurl, "sa", "");
return conn;
}
示例6: doMigrate
import org.flywaydb.core.Flyway; //導入方法依賴的package包/類
public void doMigrate(String table, String location) {
logger.info("migrate : {}, {}", table, location);
Flyway flyway = new Flyway();
flyway.setPlaceholderPrefix("$${");
// flyway.setInitOnMigrate(true);
flyway.setBaselineOnMigrate(true);
// flyway.setInitVersion("0");
flyway.setBaselineVersionAsString("0");
flyway.setDataSource(dataSource);
flyway.setTable(table);
flyway.setLocations(new String[] { location });
try {
flyway.repair();
} catch (Exception ex) {
logger.error(ex.getMessage(), ex);
}
flyway.migrate();
}
示例7: initDatasource
import org.flywaydb.core.Flyway; //導入方法依賴的package包/類
public void initDatasource(YadaConfiguration config) throws NamingException {
MysqlDataSource dataSource = new MysqlDataSource();
dataSource.setDatabaseName(config.getString("config/database/dbName"));
dataSource.setUser(config.getString("config/database/user"));
dataSource.setPassword(config.getString("config/database/password"));
dataSource.setServerName(config.getString("config/database/server"));
SimpleNamingContextBuilder builder = new SimpleNamingContextBuilder();
builder.bind("java:comp/env/jdbc/yadatestdb", dataSource);
super.dataSource = dataSource;
builder.activate();
// Database
Flyway flyway = new Flyway();
flyway.setLocations("filesystem:schema"); // Where sql test scripts are stored
flyway.setDataSource(dataSource);
flyway.clean();
flyway.migrate();
}
示例8: DBManager
import org.flywaydb.core.Flyway; //導入方法依賴的package包/類
public DBManager() {
ds = new BasicDataSource();
ds.setDriver(new EmbeddedDriver());
ds.setUrl(Constants.JDBC);
flyway = new Flyway();
flyway.setDataSource(ds);
//flyway.clean();
flyway.migrate();
// just to be sure, try to close
Runtime.getRuntime().addShutdownHook(new Thread() {
@Override
public void run() {
try {
LOG.info("Closing DB connection...");
ds.close();
LOG.info("DB closed");
} catch (SQLException ex) {
LOG.error("Error closing DB cconnection", ex);
}
}
});
}
示例9: onStartup
import org.flywaydb.core.Flyway; //導入方法依賴的package包/類
@PostConstruct
private void onStartup() throws SQLException {
if (dataSource == null) {
LOG.error("no datasource found to execute the db migrations!");
throw new EJBException(
"no datasource found to execute the db migrations!");
}
String schema = "sql" + FS + "mysql";
if (DB != null) {
schema = "sql" + FS + DB;
}
Flyway flyway = new Flyway();
flyway.setDataSource(dataSource);
flyway.setBaselineOnMigrate(true);
flyway.setPlaceholderPrefix("%{");
flyway.setLocations("sql" + FS + "configdata", schema);
flyway.setBaselineVersion(MigrationVersion.fromVersion("201609221422"));
for (MigrationInfo i : flyway.info().all()) {
LOG.info("migrate task: " + i.getVersion() + " : "
+ i.getDescription() + " from file: " + i.getScript());
}
flyway.repair();
flyway.migrate();
}
示例10: contextInitialized
import org.flywaydb.core.Flyway; //導入方法依賴的package包/類
@Override
public void contextInitialized(ServletContextEvent sce) {
ServletContext sc = sce.getServletContext();
Flyway flyway = new Flyway();
String dataSourceJndi = sc.getInitParameter(FLYWAY_JNDI_DATASOURCE);
if (dataSourceJndi != null) {
try {
DataSource dataSource = (DataSource) new InitialContext().lookup(dataSourceJndi);
flyway.setDataSource(dataSource);
} catch (NamingException ex) {
logger.log(Level.SEVERE, "Error while looking up DataSource", ex);
// Do not proceed
return;
}
} else {
String url = sc.getInitParameter(FLYWAY_JDBC_URL);
String user = sc.getInitParameter(FLYWAY_JDBC_USER);
String password = sc.getInitParameter(FLYWAY_JDBC_PASSWORD);
flyway.setDataSource(url, user, password);
}
flyway.migrate();
}
示例11: setUpClass
import org.flywaydb.core.Flyway; //導入方法依賴的package包/類
@BeforeClass
public static void setUpClass() throws Exception {
MetaDataTest.setUpClass(h2Url);
Flyway flyway = new Flyway();
flyway.setDataSource(dbSchemaUrl, "sa", "");
flyway.migrate();
Properties connInfo = new Properties();
connInfo.setProperty("url", dbSchemaUrl);
connInfo.setProperty("user", "sa");
connInfo.setProperty("password", "");
dbConnection = DriverManager.getConnection(dbSchemaUrl, connInfo);
Statement stmt = dbConnection.createStatement();
String sql = "insert into data_sources(name, type, url, ds_set_id, datasource_type) values "
+ "('H2', 'H2', '" + h2Url + "', 1, 'JDBC'); insert into jdbc_sources (id, "
+ "username, password) values(1, 'sa', '');" +
"update ds_sets set default_datasource_id = 1 where id = 1;";
stmt.execute(sql);
stmt.close();
}
示例12: setUpClass
import org.flywaydb.core.Flyway; //導入方法依賴的package包/類
@BeforeClass
public static void setUpClass() throws Exception {
MetaDataTest.setUpClass(h2Url);
Flyway flyway = new Flyway();
flyway.setDataSource(dbSchemaUrl, "sa", "");
flyway.migrate();
Properties connInfo = new Properties();
connInfo.setProperty("url", dbSchemaUrl);
connInfo.setProperty("user", "sa");
connInfo.setProperty("password", "");
dbConnection = DriverManager.getConnection(dbSchemaUrl, connInfo);
Statement stmt = dbConnection.createStatement();
String sql = "insert into ds_sets(id, name) values(10, 'ten'); " +
"insert into data_sources(name,type, url, ds_set_id, datasource_type) values "
+ "('H2', 'H2', '" + h2Url + "', 10, 'JDBC'); insert into jdbc_sources (id, "
+ "username, password) values(1, 'sa', '');" +
"update ds_sets set default_datasource_id = 1 where id = 10;";
stmt.execute(sql);
stmt.close();
}
示例13: run
import org.flywaydb.core.Flyway; //導入方法依賴的package包/類
@Override
public void run(final ServiceRegistryConfiguration configuration, final Environment environment) throws Exception {
final DataSourceFactory database = configuration.getDatabase();
// execute DB migrations
final Flyway flyway = new Flyway();
flyway.setDataSource(database.getUrl(), database.getUser(), database.getPassword());
log.debug("execute database migrations");
flyway.migrate();
log.info("database migrations successfully executed");
// create DBI instance
final DBIFactory factory = new DBIFactory();
final DBI jdbi = factory.build(environment, database, "postgresql");
environment.jersey().register(AuthFactory.binder(new BasicAuthFactory<>(
new ServiceRegistryAuthenticator(configuration.getCredentials()), "Realm", ServiceRegistryCaller.class))
);
environment.jersey().register(new ServiceResource(jdbi.onDemand(ServiceDAO.class)));
}
示例14: setUp
import org.flywaydb.core.Flyway; //導入方法依賴的package包/類
@BeforeClass
public static void setUp() throws SQLException, IOException, URISyntaxException,
ClassNotFoundException {
String[] args = new String [1];
args[0] = EndToEndTest.class.getResource("/dbCatalog.json").getPath();
main = new Main(args);
new Thread(main).start();
Flyway flyway = new Flyway();
flyway.setDataSource(dbUrl, "sa", "");
flyway.migrate();
setupTables(dbUrl, "tpcds_db.sql");
setupTables(h2Url, "tpcds.sql");
setupTables(cubeUrl, "tpcds_cubes.sql");
setupTables(viewUrl, "tpcds_views.sql");
}
示例15: setUpDb
import org.flywaydb.core.Flyway; //導入方法依賴的package包/類
@BeforeClass
public static void setUpDb() throws Exception {
SelectTest.setUpClass(dbUrl);
Flyway flyway = new Flyway();
flyway.setDataSource(dbSchemaUrl, "sa", "");
flyway.migrate();
Properties connInfo = new Properties();
connInfo.setProperty("url", dbSchemaUrl);
connInfo.setProperty("user", "sa");
connInfo.setProperty("password", "");
dbConnection = DriverManager.getConnection(dbSchemaUrl, connInfo);
Statement stmt = dbConnection.createStatement();
String sql = "insert into data_sources(name, type, url, ds_set_id, datasource_type) values "
+ "('H2', 'H2', '" + dbUrl + "', 1, 'JDBC'); insert into jdbc_sources (id, "
+ "username, password) values(1, 'sa', '');" +
"update ds_sets set default_datasource_id = 1 where id = 1;";
stmt.execute(sql);
stmt.close();
}