How does flyway sort version numbers?

2019-06-16 05:20发布

If we have migrations like:

V1_6__six.sql
V1_7__seven.sql
V1_8__eight.sql
V1_9__nine.sql

What should we use for the next version?

If we use V1_10 will that come after V1__9? Or would we need to prefix the single digit version numbers with a 0?

Really the question is: are version numbers sorted numerically or alphabetically?

标签: flyway
2条回答
倾城 Initia
2楼-- · 2019-06-16 05:53

For a definitive answer on how the sorting happens, you can refer to the code. This test is especially helpful.

@Test
public void testNumber() {
    final MigrationVersion a1 = MigrationVersion.fromVersion("1.2.13.3");
    final MigrationVersion a2 = MigrationVersion.fromVersion("1.2.3.3");
    assertTrue(a1.compareTo(a2) > 0);
}

@Test
public void testLength1() {
    final MigrationVersion a1 = MigrationVersion.fromVersion("1.2.1.3");
    final MigrationVersion a2 = MigrationVersion.fromVersion("1.2.1");
    assertTrue(a1.compareTo(a2) > 0);
}

@Test
public void testLength2() {
    final MigrationVersion a1 = MigrationVersion.fromVersion("1.2.1");
    final MigrationVersion a2 = MigrationVersion.fromVersion("1.2.1.1");
    assertTrue(a1.compareTo(a2) < 0);
}

@Test
public void leadingZeroes() {
    final MigrationVersion v1 = MigrationVersion.fromVersion("1.0");
    final MigrationVersion v2 = MigrationVersion.fromVersion("001.0");
    assertTrue(v1.compareTo(v2) == 0);
    assertTrue(v1.equals(v2));
    assertEquals(v1.hashCode(), v2.hashCode());
}
查看更多
贪生不怕死
3楼-- · 2019-06-16 05:54

In one word: numerically. As would be expected for a number.

查看更多
登录 后发表回答