无法创建包含belongsTo关系的Grails Criteria查询

时间:2010-10-29 10:09:08

标签: grails criteria gorm hibernate-criteria

我一直在尝试创建一个包含belongsTo关系的标准构建器,但还没有成功。考虑以下模型:

class Msg {
    ...
    static belongsTo = [user: User]
    ...
}  

class User {
    ...
    Organisation organisation
    ...
}  

我正在尝试进行以下查询:

Msg.createCriteria().list() {
    ...
    user {
        eq("organisation", organisationInstance)
    }
    ...
}

所有我得到的是以下错误

ERROR errors.GrailsExceptionResolver  - No signature of method: static User.call() is applicable for argument types: (MsgService$_findMessages_closure1_closure6) values: [MsgService$_findMessages_closure1_closure6@afcba8]
Possible solutions: save(), wait(), any(), getAll(), save(java.lang.Boolean), save(java.util.Map)

我尝试在条件查询中添加不同的小附加内容,例如:

join "user"
fetchMode("user", org.hibernate.FetchMode.EAGER)

但仍然遇到同样的问题。

我甚至尝试将以下静态映射添加到Msg类:

static mapping = {
    columns {
        user lazy: false
    }
}

仍然无法正常工作。

有没有办法使用包含belongsTo查询的条件构建器?

提前感谢您的帮助。
吕西安

2 个答案:

答案 0 :(得分:7)

我找到了解决方案!该问题根本与标准构建者无关。在这个例子中,我在范围内有一个用户变量。一旦移除它就像一个魅力: - )

答案 1 :(得分:2)

def criteria = Msg.createCriteria()
results = criteria.list{
    user{
        eq("organisation", organisationInstance)
    }
}