首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >优化查询PostgreSql-8.4

优化查询PostgreSql-8.4
EN

Stack Overflow用户
提问于 2011-04-20 12:56:34
回答 1查看 162关注 0票数 0

我有如下的rails控制器代码:

代码语言:javascript
复制
@checked_contact_ids = @list.contacts.all(
  :conditions => {
    "contacts_lists.contact_id" => @list.contacts.map(&:id),
    "contacts_lists.is_checked" => true
  }
).map(&:id)

它等同于sql

代码语言:javascript
复制
SELECT *
FROM "contacts"
INNER JOIN "contacts_lists" ON "contacts".id = "contacts_lists".contact_id
WHERE ("contacts_lists".list_id = 67494 ) 

上面的查询需要更多的时间来运行,我想要另一种方法来运行相同的查询最少的时间。

有没有人知道请注意我,或者这是可能的?或者,上面的查询足以给出输出吗?

本人正等候资料.....

EN

回答 1

Stack Overflow用户

发布于 2011-04-20 14:20:39

我认为原始AR查询的主要问题是它根本没有做任何连接;您通过@list.contacts从数据库中取出一堆对象,然后丢弃大部分工作,只获得ID。

第一步是用:joins => 'contact_lists'替换"contacts_lists.contact_id" => @list.contacts.map(&:id),但是您仍然需要从数据库中取出一堆东西,实例化一堆对象,然后用.map(&:id)将其全部丢弃,只获得ID号。

您已经了解SQL了,所以我可能会通过您的列表模型(或任何@list )上的一个方便的方法直接使用SQL,如下所示:

代码语言:javascript
复制
def checked_contact_ids
    connection.execute(%Q{
        SELECT contacts.id
        FROM contacts
        INNER JOIN contacts_lists ON contacts.id = contacts_lists.contact_id
        WHERE contacts_lists.list_id    = #{self.id}
          AND contacts_lists.is_checked = 't'
    }).map { |r| r['id'] }
end

然后,在你的控制器中:

代码语言:javascript
复制
@checked_contact_ids = @list.checked_contact_ids

如果这还不够快,那么请检查contacts_lists表上的索引。

当您确切地知道需要什么数据并且很快就需要它时,没有理由不直接使用SQL;只要将SQL隔离在您的模型中,就不会有任何问题。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5725697

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档