日期:2014-05-16  浏览次数:20477 次

使用maven-sql-plugin实现持续数据库集成(CDBI)

数据库持续集成(Continuous Database Integration, CDBI)是持续集成(Continuous Ingeration, CI)不可或缺的重要组成部分。在典型的情况下,版本控制系统管理数据库脚本,包括数据库定义语言(DDL)和数据库操纵语言(DML)。开发成员在开发过程中添加或者修改数据库脚本,在本地运行过之后,提交至版本控制系统,并由此激发一次持续构建。CI服务器执行数据库脚本,并返回成功或者错误报告。

?

第18界Jolt大奖,技术类图书获得者: Continuous Integration: Improving Software Quality and Reducing Risk 用一章的篇幅介绍的CDBI的相关概念及实践,并给出了一个基于Ant的样例实现,本文将介绍使用Maven来实现CDBI。

?

首先简单介绍一下 SQL Maven Plugin ,它通过Maven来执行配置好的数据库脚本,可以通过在POM中配置sql命令,或者将脚本写在文件中,在POM中配置文件位置。最后,运行 mvn sql:execute 以执行所有脚本。

?

以下通过一个比较完整的例子来解释下该插件的用法,这里例子能在这里找到:http://mojo.codehaus.org/sql-maven-plugin/examples/execute.html

?

首先,配置对 sql-maven-plugin 的依赖:

?

Xml代码 复制代码?收藏代码
  1. <build>??
  2. ??[...] ??
  3. ??????<plugin>??
  4. ????????<groupId>org.codehaus.mojo</groupId>??
  5. ????????<artifactId>sql-maven-plugin</artifactId>??
<build>
  [...]
      <plugin>
        <groupId>org.codehaus.mojo</groupId>
        <artifactId>sql-maven-plugin</artifactId>

紧接着,由于该插件需要使用JDBC来执行SQL脚本,因此还需要配置对JDBC驱动的依赖,如:

?

Xml代码 复制代码?收藏代码
  1. <dependencies>??
  2. ??<!--?specify?the?dependent?jdbc?driver?here?-->??
  3. ??<dependency>??
  4. ????<groupId>postgresql</groupId>??
  5. ????