繁体   English   中英

Grails命名查询-通过关联查找

[英]Grails named query - find by association

我想创建一个命名查询,该查询将基于子类属性的一个或多个属性找到一个类的所有对象。

我希望能够找到所有Foo.me ==“ some string”的酒吧

所以,我有这个,它不起作用:

class Foo {
    String me
}

class Bar {
    Foo foo

    static namedQueries = {
        findByFooMe { meStr ->
            eq(foo.me, meStr)
        }
    }
}

正确的语法是什么样的? 另外,如果Bar具有很多Foos,并且我想查找其Foo,me属性之一是“搜索字符串”的所有Bar,它将如何改变?

class Bar {
    static hasMany [foos: Foo]
} 

虽然我不建议将findBy用作命名查询的前缀,但是您接近正确的实现。 这也是该查询的更新版本,也带有新名称。

static namedQueries = {
    locateByFooMe { meStr ->
        foo {
          eq('me', meStr)
        }
    }
}

如果您更改与集合的关系(一对多),只需确保将属性名称foo (在这种情况下)更改为您将其更改为的任何名称(问题中的foos ),以上查询仍将继续起作用。

暂无
暂无

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

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