maven mysql插件_maven:sql-maven-plugin插件执行sql脚本

sql-maven-plugin插件提供了sql脚本的执行功能,允许用户执行指定的sql脚本文件或语句。

最近在进行一个项目是基于maven管理的java开发项目,其中有一个环节要对数据库初始化创建表,需要在maven中执行,正好有机会学习了sql-maven-plugin的使用.

下面的maven脚本实现的功能就是在mysql数据库中执行指定的sql脚本(create_tables.sql)来创建表:

run-sql.xml

4.0.0

yourGroupId

yourArtifactId

maven-plugin

facelog-sql

org.codehaus.mojo

sql-maven-plugin

1.5

mysql

mysql-connector-java

5.1.43

com.mysql.jdbc.Driver

jdbc:mysql://localhost:3306/test

root

${project.basedir}/sql/create_tables.sql

运行方式如下:

# 因为上面的脚本我没有使用缺省的文件名pom.xml,所以maven执行的时候要用-f 指定文件名

mvn -f run-sql.xml sql:execute

定义多个独立执行的execution

上面的脚本可以一次性执行一个或多个sql脚本,如果我们希望每个脚本可以在命令行分别独立执行,那么就要定义多个execution来实现。

比如我们将删除表的语句和建表语句分成两个文件(clean_tables.sql,create_tables.sql),希望在命令行分别执行两个脚本,那么 上面脚本就修改成如下的样子:

4.0.0

net.gdface.facelog

facelog-sql

maven-plugin

facelog-sql

org.codehaus.mojo

sql-maven-plugin

1.5

mysql

mysql-connector-java

5.1.43

com.mysql.jdbc.Driver

jdbc:mysql://localhost:3306/test

root

clean-tables

${project.basedir}/sql/clean_tables.sql

create-tables

${project.basedir}/sql/create_tables.sql

命令行执行如下:

# 通过@execution-id的方式指定执行id为‘clean-tables’的execution

mvn -f run-sql.xml sql:execute@clean-tables

# 通过@execution-id的方式指定执行id为‘create-tables’的execution

mvn -f run-sql.xml sql:execute@create-tables

参考资料:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值