[英]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.