2016-05-16 9 views
2

繰り返し可能な移行を使用しているとき、私はいくつかの奇妙な飛行経路の動作を観察しています。フライウェイ反復可能な移行 - バージョン管理されたものより前に実行されますか?

1回のマイグレーション実行では、保留中のバージョン化されたマイグレーションがすべて実行された後で、繰り返し可能なマイグレーションが常に最後に適用されます。

私の場合は、バージョン管理された移行の前に実行されているため、再現可能な移行(DBビューの再作成中)は失敗しているようです。移行前から

フライウェイ情報データ、: +-------------------+---------------------+---------------------+---------+ | Version | Description | Installed on | State | +-------------------+---------------------+---------------------+---------+ | 1 | Initial | | <Baseln | | 2 | ███████████████████ | | <Baseln | | 5 | Initial data | | <Baseln | | 6 | Initial sample data | 2016-04-29 14:21:13 | Success | | 20160422002600000 | ███████████████████ | 2016-04-29 14:33:48 | Success | | 20160422003400000 | ███████████████████ | 2016-04-29 14:33:48 | Success | | 20160422004700000 | ███████████████████ | 2016-04-29 14:33:48 | Success | | 20160428152800000 | ███████████████████ | 2016-04-29 14:33:48 | Success | | 20160428163300000 | ███████████████████ | 2016-04-29 14:33:48 | Success | | 20160428171300000 | ███████████████████ | 2016-04-29 14:33:48 | Success | | | ProblematicView | 2016-04-29 14:33:48 | Outdate | | | Reports | 2016-04-29 14:33:49 | Success | | | OtherView | 2016-04-29 14:33:49 | Success | | 20160429115100000 | ███████████████████ | 2016-04-29 14:37:10 | Success | | 20160429160100000 | ███████████████████ | 2016-05-16 11:54:24 | Success | | 20160501090500000 | ███████████████████ | 2016-05-16 11:54:24 | Success | | 20160504111600000 | ███████████████████ | 2016-05-16 11:54:24 | Success | | 20160504120400000 | ███████████████████ | 2016-05-16 11:54:24 | Success | | 20160504143800000 | ███████████████████ | 2016-05-16 11:54:24 | Success | | 20160504145200000 | ███████████████████ | 2016-05-16 11:54:25 | Success | | 20160504161600000 | ███████████████████ | | Pending | | 20160506110300000 | ███████████████████ | | Pending | | 20160506162300000 | ███████████████████ | | Pending | | 20160506232000000 | ███████████████████ | | Pending | | 20160508144100000 | ███████████████████ | | Pending | | 20160509192400000 | ███████████████████ | | Pending | | 20160511160000000 | ███████████████████ | | Pending | | 20160511163659000 | ███████████████████ | | Pending | | 20160511163700000 | A newly_created_col | | Pending | | 20160511170000000 | ███████████████████ | | Pending | | 20160512112100000 | ███████████████████ | | Pending | | 20160512170500000 | ███████████████████ | | Pending | | 20160513134900000 | ███████████████████ | | Pending | +-------------------+---------------------+-------------------------------+

と移行ログ:

[INFO] Database: jdbc:sqlserver://█:1433;authenticationScheme=nativeAuthentication;xopenStates=false;sendTimeAsDatetime=true;trustServerCertificate=false;sendStringParametersAsUnicode=true;selectMethod=direct;responseBuffering=adaptive;packetSize=8000;multiSubnetFailover=false;loginTimeout=15;lockTimeout=-1;lastUpdateCount=true;encrypt=false;disableStatementPooling=true;databaseName=█;applicationName=Microsoft JDBC Driver for SQL Server;applicationIntent=readwrite; (Microsoft SQL Server 11.0) 
[INFO] Successfully validated 33 migrations (execution time 00:00.052s) 
[INFO] SQLServer does not support setting the schema for the current session. Default schema NOT changed to dbo 
[INFO] Current version of schema [dbo]: 20160504145200000 
[WARNING] outOfOrder mode is active. Migration of schema [dbo] may not be reproducible. 
[INFO] Migrating schema [dbo] with repeatable migration ProblematicView 
[ERROR] Migration of schema [dbo] with repeatable migration ProblematicView failed! Changes successfully rolled back. 
[INFO] SQLServer does not support setting the schema for the current session. Default schema NOT changed to dbo 
[INFO] ------------------------------------------------------------------------ 
[INFO] BUILD FAILURE 
[INFO] ------------------------------------------------------------------------ 
[INFO] Total time: 3.550s 
[INFO] Finished at: Mon May 16 12:40:49 CEST 2016 
[INFO] Final Memory: 10M/243M 
[INFO] ------------------------------------------------------------------------ 
[ERROR] Failed to execute goal org.flywaydb:flyway-maven-plugin:4.0.1:migrate (migrate-¦) on project ¦-db: org.flywaydb.core.internal.dbsupport.FlywaySqlScriptException: 
[ERROR] Migration R__ProblematicView.sql failed 
[ERROR] ------------------------------------------------ 
[ERROR] SQL State : S0001 
[ERROR] Error Code : 207 
[ERROR] Message : Invalid column name 'newly_created_column'. /*<-- column created in V20160511163700000*/` 

私が何か間違ったことをやっていますか?
私は次のプロパティを持つ(4.0にも試験)フライウェイ - のmaven-pluginの4.0.1を使用しています:

Maven: 
<cleanDisabled>true</cleanDisabled> 
<outOfOrder>true</outOfOrder> 
<table>schema_version</table> 
<repeatableSqlMigrationPrefix>R</repeatableSqlMigrationPrefix> 
<sqlMigrationPrefix>V</sqlMigrationPrefix> 
Config file: 
flyway.user=flyway 
flyway.password=█ 
flyway.url=jdbc:sqlserver://█;databasename=█ 
flyway.locations=filesystem:flyway/upgrade/█` 

// EDIT1: outOfOrderがfalseに設定されている

  1. clean + migrateが正常に動作しているように見えますが、それでも問題は解決しません。
  2. DBをバージョン201605041にロールバックしたとき43800000の繰り返し可能な移行はリストの最後に表示されますが、20160504145200000の移行が突然実行されたときに突然それらは途中にあります(上記の表のように)。これは実際の実行命令と関係があるかどうかはわかりません。

答えて

3

Flywayのバグと判明したのはLINK - リリース4.0 - 4.0.2に影響し、4.0.3(Release notes)で修正されました。

空のデータベースと既存のデータベースの両方で期待どおりに動作することが確認できました。

0

の移行が唯一自分の定義された順序で起こることができるようにそれはあなたがfalseに outOfOrderプロパティを変更する価値があるだろう。

まだ問題が発生している場合は、cleanDisabledをfalseに設定して、スキーマが完全に再構築され、表示内容が報告されるようにすることもできます。

上記の両方が、より特定の方法で動作するようになり、他の人がイベントの順序についてより確実にコメントできるようになります。

+0

ありがとう、私はOPを更新しました。 –

関連する問題