避免在ActiveRecord中显示SHOW FIELDS

时间:2009-12-21 15:12:12

标签: ruby-on-rails activerecord

有什么方法可以阻止ActiveRecord在不需要时向数据库发出SHOW FIELDS?

我正在研究数据库性能关键应用程序,并且注意到在典型查询中我的SELECT需要0.5毫秒,相关的SHOW FIELDS需要2毫秒 - 4倍长!更重要的是,它不是必需的,因为我已经指定了我想要检索的唯一列:

UsersAddress.find(:all, :conditions => {:user_id => 1}, :select => :address_id)

  

UsersAddress加载(0.5ms)SELECT address_id FROM users_addresses WHERE(users_addressesuser_id = 1)

     

UsersAddress列(2.1ms)显示来自users_addresses

的字段

当然,这只是每次第一次触摸某个表时才会发生一次,但不应该是可以避免完成的吗?首先,该信息已经在我的架构中。其次,我不需要它。

任何想法如何优化这一点,以便Rails不会运行SHOW FIELDS,除非真的需要它?

谢谢!

2 个答案:

答案 0 :(得分:11)

在生产模式下,它将在启动服务器后加载一次(不是每个请求)。

在开发模式下,它会在每个请求上加载(因为它是开发模式,并且几乎每次请求都会重新启动)

所以你不必在生产模式下担心它。

答案 1 :(得分:0)