题
我正在使用 Groovy Sql 来获取结果。这是我的 Linux 机器的输出。
%isql -U abc -P abc -S support
1> sp_configure 'number of open partitions'
2> go
Parameter Name Default Memory Used Config Value Run Value Unit Type
------------------------------ ----------- ----------- ------------ ------------ -------------------- ----------
number of open partitions 500 5201 5000 5000 number dynamic
(1 row affected)
(return status = 0)
1>
我正在使用常规代码
def sql = Sql.newInstance("jdbc:abc:sybase://harley:6011;DatabaseName=support;",dbuname,dbpassword,Driver)
sql.eachRow("sp_configure 'number of open partitions'"){ row ->
println row.run_value
}
但它给了我
Exception in thread "main" java.sql.SQLSyntaxErrorException: [abc][Sybase JDBC Driver]Invalid column name: run_value
所以它说它无法获取指定的列,有没有办法可以获取结果并显示?
更新
我使用了下面的代码
sql.eachRow("sp_configure 'number of open partitions'"){ row ->
println row
}
它给了我
[Parameter Name:number of open partitions , Default: 500, Memory Used: 5201, Config Value: 5000, Run Value: 5000, Unit:number , Type:dynamic ]
我怎样才能得到 Run Value
?(因为里面有空格)
row.Run Value
肯定行不通
解决方案
这有效吗?查询元数据中的列名并通过索引获取值:
sql.eachRow("sp_configure 'number of open partitions'"){ row ->
(1..row.getMetaData().columnCount).each {
println "${row.metaData().getColumnName( it )} = ${row[ it ]}"
}
}
或者,直接获取列
row.'Run Value'
其他提示
另一种选择是 getAt(int)。在您的情况下,这将返回“运行值”:
row.getAt(-3)
除了@tim_yates 的回答之外,我还想指出的是 row
有 toRowResult()
方法。它允许简单地获取一行作为 Map。无需打电话 getMetadata()
如果我们只需要列名或表宽度。
sql.eachRow("sp_configure 'number of open partitions'"){ row ->
row.toRowResult().each(){ colName, value ->
println "${colName} = ${value}"
}
}
这段代码的作用完全相同,但看起来更清晰
不隶属于 StackOverflow