加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails – 避免在ActiveRecord中显示SHOW FIELDS

发布时间:2020-12-16 19:22:34 所属栏目:百科 来源:网络整理
导读:有什么办法可以阻止ActiveRecord在不需要时向数据库发出SHOW FIELDS吗? 我正在研究数据库性能关键应用程序,并且注意到在典型查询中,我的SELECT需要0.5毫秒,相关的SHOW FIELDS需要2毫秒 – 4倍长!更重要的是,它不是必需的,因为我已经指定了我想要检索的唯一
有什么办法可以阻止ActiveRecord在不需要时向数据库发出SHOW FIELDS吗?

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

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

UsersAddress Load (0.5ms) SELECT address_id FROM users_addresses WHERE (users_addresses.user_id = 1)

UsersAddress Columns (2.1ms) SHOW FIELDS FROM users_addresses

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

任何想法如何优化这样,以便Rails不会运行SHOW FIELDS,除非它确实需要它?

谢谢!

解决方法

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

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

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读