Maven原型在执行Groovy脚本时引发错误

fgw7neuy  于 2022-11-01  发布在  Maven
关注(0)|答案(1)|浏览(170)

我制作了一个定制的maven原型,并基于Maven Documentation,将文件 archetype-post-generate.groovy 添加到 src/main/resources/META-INF 文件夹中。
在这个groovy脚本中,我想连接到一个数据库,并根据数据采取一些操作。
脚本如下:

import groovy.sql.Sql

Sql.withInstance(
        'jdbc:sqlserver://localhost:1433;databaseName=db;',
        'sa',
        'pass',
        'com.microsoft.sqlserver.jdbc.SQLServerDriver') { sql ->
    List rows = sql.rows('SELECT top 5 id, description FROM Project')
    for(row in rows) {
        println row.getProperty("id")
        println row.getProperty("description")
        println "/*************\\"
    }
}

在安装原型之后,当我用它生成一个模块时,一旦执行脚本,就会引发以下错误:

Failed to execute goal org.apache.maven.plugins:maven-archetype-plugin:3.2.0:generate (default-cli) on project standalone-pom: startup failed:
Script1.groovy: 1: unable to resolve class groovy.sql.Sql
 @ line 1, column 1.
   import groovy.sql.Sql
   ^

1 error

有什么办法可以解决这个问题吗?

oo7oh9g9

oo7oh9g91#

根据@emilles的指导和Groovy documentation,我们可以使用@Grab注解将任何库添加到脚本的类路径中。
例如:

@Grab('org.codehaus.groovy:groovy-sql:2.4.16')
@Grab('com.microsoft.sqlserver:mssql-jdbc:8.4.1.jre8')

相关问题