gpt4 book ai didi

hibernate - Grails 3-使用条件在字符串列表中查找字符串

转载 作者:行者123 更新时间:2023-12-02 15:49:59 25 4
gpt4 key购买 nike

我具有以下域类,并且想要查找所有以组名开头(如果输入了组名)并且包含一个groupStrings(如果输入了组字符串)的组:

class Group {
String name
List groupStrings
static hasMany = [
groupStrings : String
]
}

我试过了:
String groupNameToFind = ...
String groupStringToFind = ...

List<Long> groupIds = Group.createCriteria().listDistinct() {
projections {
property 'id'
}
if(groupNameToFind) {
ilike('name', groupNameToFind + '%')
}
if(groupStringToFind) {
eq('groupStrings', groupStringToFind)
}
}

我也尝试过:
List<Long> groupIds = Group.createCriteria().listDistinct() {
projections {
property 'id'
}
if(groupStringToFind) {
createAlias('groupStrings', 'gs', JoinType.LEFT_OUTER_JOIN)
eq('gs', groupStringToFind)
}
if(groupNameToFind) {
ilike('name', groupNameToFind + '%')
}
}

尝试查找组字符串时,这两种方法都会产生错误。正确的语法是什么?

最佳答案

您的域名有点奇怪。我会把两个域不只是一个。您需要一个组域和一个组字符串域。该组可以具有hasMany GroupString,而GroupString可以只是一个字符串,并且可能属于。我认为这将是通过查询做到这一点的唯一方法。
否则,您可以获取所有组并执行.find {closure}

关于hibernate - Grails 3-使用条件在字符串列表中查找字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40918945/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com