为了账号安全,请及时绑定邮箱和手机立即绑定

navicat中如何查看执行一条SQL语句的耗时

navicat中如何查看执行一条SQL语句的耗时

一只萌萌小番薯 2019-03-06 10:15:59
在软件Navicat中,如何查看执行一条SQL语句的耗时。如select * from table_name where id = '1' 如何查看当前的语句耗时。==============================================================通过测试发下:SELECT * FROM idc_logistics_assign_rules WHERE id = '100';SELECT * FROM idc_logistics_assign_rules WHERE id = '200';//时间: 0.035sSELECT * FROM idc_logistics_assign_rules WHERE id IN ('100','200')//时间: 0.020s我的id是主键,肯定会走索引的,那么走索引的查询应该更快啊。使用IN关键字是不走索引的,但是为什么查询要比两次主键id查询块呢?求解释。
查看完整描述

5 回答

?
斯蒂芬大帝

TA贡献1827条经验 获得超8个赞

你这里in是走索引的,执行下explain SELECT * FROM idc_logistics_assign_rules WHERE id IN ('100','200') 你会看到索引使用情况,它是有用到索引的。要得到正确点的查询时间的话加个 SQL_NO_CACHE

SELECT SQL_NO_CACHE * FROM idc_logistics_assign_rules WHERE id IN ('100','200')

注意:in用不用索引?根据情况而定。即根据是否能够利用索引而定。当in的范围是聚集索引 in(1,2) 会被MSSQL自动优化成id=1 or id=2 ,你可以使用explain看下,他返回的row是2 in(1,2)与id=1 or id=2 explain返回的数据都是一样的。我可以很负责的告诉你是有用索引。网上很多提及不走索引的大部分都是旧资料,MSSQL2K以后已经优化了。


查看完整回答
反对 回复 2019-04-24
?
慕容3067478

TA贡献1773条经验 获得超3个赞

你的id是int类型吧。为什么查询的时候,要加单引号


查看完整回答
反对 回复 2019-04-24
?
蓝山帝景

TA贡献1843条经验 获得超7个赞

右下角有查询时间 以秒为单位


查看完整回答
反对 回复 2019-04-24
  • 5 回答
  • 0 关注
  • 6263 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信