Groovy Sql从列中获取最大值

我有以下Groovy代码从’topic’表中的’id’列返回最大值:

def rs = sql.executeQuery("select max(id) from topic")

 def maxId = rs.getLong(1)

它不起作用,我收到以下错误:

java.sql.SQLException: Invalid column index
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:113)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:147)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:209)…

有谁知道正确的代码是什么?
谢谢.

解决方法

我认为如果你使用firstRow方法会更容易.您可以通过名称或索引从结果对象中获取值.

按名字:

def row = sql.firstRow("select max(id) as max from topic")
def maxId = row.max

按索引:

def row = sql.firstRow("select max(id) from topic")
def maxId = row[0]

相关文章

背景:    8月29日,凌晨4点左右,某服务告警,其中一个...
https://support.smartbear.comeadyapi/docs/soapui/steps/g...
有几个选项可用于执行自定义JMeter脚本并扩展基线JMeter功能...
Scala和Java为静态语言,Groovy为动态语言Scala:函数式编程,...
出处:https://www.jianshu.com/p/ce6f8a1f66f4一、一些内部...
在运行groovy的junit方法时,报了这个错误:java.lang.Excep...