读书人

运用maven-sql-plugin实现持续数据库集

发布时间: 2012-07-29 15:26:13 作者: rapoo

使用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 的依赖:

?

          <!-- drop db after test -->          <execution>            <id>drop-db-after-test</id>            <phase>test/phase>            <goals>              <goal>execute</goal>            </goals>            <configuration>              <autocommit>true</autocommit>              <sqlCommand>drop database yourdb</sqlCommand>            </configuration>          </execution>        </executions>      </plugin>  [...]

最后让我们回头再来看看这个五个步骤,其实它们都用了 sql-maven-plugin 的 execute 目标,除了drop-db-after-test,它们都配置了 process-test-resources 生命周期。这样配置的目的是让删旧库,建库,建表,插数据这些步骤在测试之前完成,这样,测试的时候就有一个完好的数据库了,测试完了之后,再把建好的数据库删除。

通过建一个Maven项目,使用 maven-sql-plugin 管理数据库脚本的执行,然后使用CI服务器来调用这个Maven项目,我们就可以实现基于Maven的CDBI了。

1 楼 jgyhuzhou 2008-06-25 it's very useful for integrate test, thanks! 2 楼 yeah1900 2008-06-27 有效的把数据库操作和测试集成起来,不错 3 楼 nasvel 2008-07-22 很有启发,我一直用dbunit来做单元测试,觉得相对sql-plugin来:
1 不需要另外维护SQL脚本
2 可以对各单元测试插入不同的测试数据,避免unit test A更改数据造成unit test B的失败
3 toplink 和 hibernate 都支持动态创建删除表

另外我看到代码中的各executions已经连接到maven的lifecycle中了,所以我觉得执行以上命令应该使用:mvn package 而不是 mvn sql:execute 4 楼 lovefly_zero 2008-07-25 很好 谢谢~ 5 楼 juvenshun 2008-07-25 maven-sql-plugin不是用来做单元测试的,而是CDBI。dbunit或者spring基于事务的单元测试框架都能很好的服务于依赖于数据库的单元测试。而CDBI主要的作用还是自动化维护项目的sql脚本。 6 楼 fanwenqiang666 2010-01-07 爷们很专业,顶一个 7 楼 hobitton 2011-11-25 http://mojo.codehaus.org/sql-maven-plugin/examples/execute.html。。。 8 楼 doujiang327 2012-03-12 先说,《maven实战》写的不错,我买了两本。
提个问题,我在创建数据库的时候要是想指定编码格式该怎么写?

读书人网 >其他数据库

热点推荐