Liquibase:diff总是生成索引

时间:2017-09-02 23:59:21

标签: java spring maven spring-boot liquibase

我使用spring-boot和liquibase-maven-plugin根据我的类生成数据库更改,但是" mvn编译liquibase:diff"命令始终生成索引和外键的删除和包含,即使数据库已更新且类中没有更改(因此数据库中也不应更改)。

任何人都知道这是否正确或如何避免它?我只希望在项目的变更集中生成对数据库的新更改。

1 个答案:

答案 0 :(得分:1)

首先,我认为您缺少liquibase-hibernate4 maven插件。

来自项目Readme.md

  

此扩展允许您将Hibernate配置用作Liquibase中diff,diffChangeLog和generateChangeLog的比较数据库。

这实际上意味着您可以使用它来将实际数据库与Java实体进行比较,以生成新的变更日志。

正如项目Wiki所建议的那样,请记住,您需要查看新的变更日志并在出现问题时手动对其进行修改。

我还建议您阅读此article from Baeldung,该解释说明:

您的pom.xml应该如下所示:

...
<dependencies>
  ...
  <dependency>
    <groupId>org.liquibase</groupId>
    <artifactId>liquibase-core</artifactId>
    <version>3.4.1</version>
  </dependency>
  <dependency>
    <groupId>org.liquibase</groupId>
    <artifactId>liquibase-maven-plugin</artifactId>
    <version>3.4.1</version>
  </dependency> 
  ...
</dependencies>
...
<plugins>
    ...
    <plugin>
    <groupId>org.liquibase</groupId>
    <artifactId>liquibase-maven-plugin</artifactId>
    <version>3.4.1</version>
    <configuration>                  
        <propertyFile>src/main/resources/liquibase.properties</propertyFile>
    </configuration> 
    <dependencies>
        <dependency>
            <groupId>org.liquibase.ext</groupId>
            <artifactId>liquibase-hibernate4</artifactId>
            <version>3.5</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-beans</artifactId>
            <version>4.1.7.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.data</groupId>
            <artifactId>spring-data-jpa</artifactId>
            <version>1.7.3.RELEASE</version>
        </dependency>
    </dependencies>               
</plugin>  
    ...
</plugins>
...

还有您的src/main/resources/liquibase.properties

url=jdbc:mysql://localhost:3306/your_db
username=your_user
password=your_pw
driver=com.mysql.jdbc.Driver #orYourDriver
outputChangeLogFile=src/main/resources/liquibase-outputChangeLog.xml
hibernate:spring:your.model.package?dialect=org.hibernate.dialect.MySQLDialect&hibernate.physical_naming_strategy=org.springframework.boot.orm.jpa.hibernate.SpringPhysicalNamingStrategy&hibernate.implicit_naming_strategy=org.springframework.boot.orm.jpa.hibernate.SpringImplicitNamingStrategy

我不确定您使用的是哪种持久性存储,但请确保使用正确的驱动程序和数据源url。

完整配置它之后,您应该可以运行mvn liquibase:diffChangeLog来生成新的变更日志。