首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用Count和Explain

使用Count和Explain
EN

Stack Overflow用户
提问于 2016-01-16 00:59:49
回答 1查看 147关注 0票数 1

在Rails中,有一个有用的方法可以显示一个查询需要多长时间以及它是什么查询。

方法是“解释”。

所以我可以这样做:

代码语言:javascript
复制
User.where(name: 'Johnny').explain

它将显示实际的sql查询。

'count‘方法也进行sql查询,但由于'count’返回一个数字,而不是活动记录,所以我不能对它使用explain。有没有办法做到这一点?

EN

回答 1

Stack Overflow用户

发布于 2016-01-16 01:04:23

这是可行的:

代码语言:javascript
复制
User.select('count(*)').where(name: 'Johnny').explain

编辑:这确实是完全相同的:

代码语言:javascript
复制
irb(main):004:0> Benutzer.where(login: 'xxx').count
   (2.2ms)  SELECT COUNT(*) FROM "BENUTZER" WHERE "BENUTZER"."LOGIN" = 'xxx'
=> 0
irb(main):005:0> Benutzer.select("count(*)").where(login: 'xxx').explain
  Benutzer Load (0.9ms)  SELECT count(*) FROM "BENUTZER" WHERE "BENUTZER"."LOGIN" = 'xxx'
=> EXPLAIN for: SELECT count(*) FROM "BENUTZER"  WHERE "BENUTZER"."LOGIN" = 'xxx'
Plan hash value: 1339361075

-------------------------------------------------------------------------------
| Id  | Operation          | Name     | Rows  | Bytes | Cost (%CPU)| Time     |
-------------------------------------------------------------------------------
|   0 | SELECT STATEMENT   |          |     1 |    12 |     2   (0)| 00:00:01 |
|   1 |  SORT AGGREGATE    |          |     1 |    12 |            |          |
|*  2 |   TABLE ACCESS FULL| BENUTZER |     1 |    12 |     2   (0)| 00:00:01 |
-------------------------------------------------------------------------------

Predicate Information (identified by operation id):
---------------------------------------------------

   2 - filter("BENUTZER"."LOGIN"='xxx')

Note
-----
   - dynamic sampling used for this statement (level=2)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34816137

复制
相关文章

相似问题

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