2

我正在使用 PublicActivity gem:https ://github.com/pokonski/public_activity

我使用 PublicActivity 跟踪的所有模型都使用该列edition_id。而且我想知道如何通过该列确定范围,因为它是多态关系。

例如 PublicActivity 看起来像这样:

PublicActivity::Activity.limit(50)

+----+--------------+----------------+----------+------------+--------------------+------------+--------------+----------------+---------------------------+---------------------------+
| id | trackable_id | trackable_type | owner_id | owner_type | key                | parameters | recipient_id | recipient_type | created_at                | updated_at                |
+----+--------------+----------------+----------+------------+--------------------+------------+--------------+----------------+---------------------------+---------------------------+
| 1  | 42           | QuizMaster     | 6        | User       | quiz_master.update | {}         |              |                | 2013-04-12 17:33:14 +0100 | 2013-04-12 17:33:14 +0100 |
| 2  | 25           | Place          | 6        | User       | place.update       | {}         |              |                | 2013-04-12 17:42:42 +0100 | 2013-04-12 17:42:42 +0100 |
| 3  | 25           | Event          | 6        | User       | event.update       | {}         |              |                | 2013-04-12 17:45:08 +0100 | 2013-04-12 17:45:08 +0100 |
| 4  | 20           | QuizMaster     | 6        | User       | quiz_master.update | {}         |              |                | 2013-04-12 17:49:09 +0100 | 2013-04-12 17:49:09 +0100 |
| 5  | 20           | QuizMaster     | 6        | User       | quiz_master.update | {}         |              |                | 2013-04-12 17:50:51 +0100 | 2013-04-12 17:50:51 +0100 |
+----+--------------+----------------+----------+------------+--------------------+------------+--------------+----------------+---------------------------+---------------------------+

其中 edition_id 在多态可跟踪关系上。

我想做的是:

PublicActivity::Activity.limit(50).includes(:trackable)# where trackable edition = 1

我不确定如何甚至是否可以跨多个“可跟踪”类型加入或包含或预加载多态模型。

4

1 回答 1

2

由于多态性,我认为这不可能直接使用 SQL,但是你可以很容易地用 ruby​​ 做一些事情。

PublicActivity::Activity.limit(50).select {|c| c.trackable.edition_id = 1 }

它不会像 SQL 查询那样高效,但使用 Railspreload可能就足够了,具体取决于您要获取的记录数量。

PublicActivity::Activity.limit(50).preload(:trackable).select {|c| c.trackable.edition_id = 1 }
于 2014-07-19T12:25:56.630 回答