Grails Criteria Projections - 两个属性的独特投影

时间:2016-12-19 15:52:26

标签: grails gorm criteria

我希望使用Grails Criteria Projections获得两列的所有可能组合。

我试试这个:

def criteria = {
   projections{
        property('colA')
        property('colB')
   }
}

def allCombinations = MyDomainEntity.createCriteria().list(criteria)

但是,该代码返回colA和colB的所有重复组合。

我还尝试使用distinct,但仅适用于单个列。

有什么想法可以解决这个问题吗?

谢谢!

1 个答案:

答案 0 :(得分:1)

我不知道您尝试解决的实际问题,但根据您所说的,您应该使用groupProperty

以下是示例:

// Your domain class
class TestEntity {
   String field1
   String field2
}

// test distinct projection
class TestEntityTest extends GroovyTestCase {

    void testDistinctByTwoColumns() {
        new TestEntity(field1: 'test1', field2: 'test2').save()
        new TestEntity(field1: 'test1', field2: 'test2').save() // duplicate
        new TestEntity(field1: 'test1', field2: 'test2').save() // duplicate
        new TestEntity(field1: 'test3', field2: 'test4').save()
        final result = TestEntity.withCriteria {
            projections {
                groupProperty('field1')
                groupProperty('field2')
            }
        }
        assertEquals(2, result.size())
    }
}

P.S。我使用Grails 2.5.5进行测试。也许你的版本有点不同,但我希望这个想法很明确。