繁体   English   中英

ID字段上的Grails搜索会引发错误

[英]Grails search on id field throws an error

我有一个搜索页面,用户应该能够根据他们的ID(GORM生成的id,而不是我的域类中的属性)或者他们的名字来搜索作者。 当我搜索作者的名字时,搜索页面工作正常但是当我们尝试搜索他们的ID时,我得到下面的错误。

信息:

java.lang.String cannot be cast to java.lang.Long

请让我知道如何解决这个问题。

这是我在控制器中的搜索方法:

def search(Integer max) {
    params.max = Math.min(max ?: 10, 100)

    def authorList = Author.createCriteria().listDistinct () {
        if ( params.id ) {
            eq("id", "%${params.id}%")
        }
        if ( params.name ) {
            ilike("name", "%${params.name}%")
        }


    respond authorList, model:[authorInstanceCount: Author.count()]
}

替换这个:

eq("id", "%${params.id}%")

eq("id", params.long('id'))

params.long('id')尝试将参数安全地转换为Long ,即如果无法执行转换而不是抛出异常,它将返回null

您获得的例外情况非常丰富。 你试图通过java.lang.String ,其中到位java.lang.Long是必需的。 传递params.id而不将其转换为字符串:

eq("id", params.id) // if params.id is java.lang.Long
// or
eq("id", params.id.toLong()) // if params.id is java.lang.String

在关闭listDistinct()方法之后你也错过了关闭大括号listDistinct()在复制粘贴期间可能是一个错误)。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM