查询Grails中的多个域对象

时间:2011-02-03 07:08:27

标签: grails

我正在构建一个“最近活动”页面,只是为了给出一些背景信息。基本上,这个页面将是用户执行的几个不同动作的混搭。问题是这些数据跨越多个(大约3个)域对象类型,所有这些都具有不同的字段。所有域都与User对象相关联,但关联不同。

域名是UserPost,FriendRequest和UserTask。有没有办法可以查询所有这些域,支持分页,并按dateCreated排序?改变我的结构会更好吗?任何帮助都会很棒!

1 个答案:

答案 0 :(得分:5)

我已经为我的网站实现了类似的功能,我得出的结论是,最好添加一个记录所有类型活动的Activity域类。 我们说

class Activity {
  Date dateCreated
  String linkClassName
  Long linkId

  def getLink() { getClass().classLoader.loadClass(linkClassName).get(linkId) }
}

然后,无论何时在UserPost,FriendRequest和UserTask(或其他)中插入新记录,您都可以使用afterInsert GORM events在Activity中创建新条目,如下所示:

def afterInsert = {
  new Activity(linkClassName: this.class.name, linkId: this.id).save()
}

完成此操作后,您可以检索最近的活动:

def activities = Activity.list(max: 5, sort:'dateCreated', order:'desc')