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

发布于 2022-09-03 12:55:44 字数 489 浏览 18 评论 0

在软件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.035s

SELECT * FROM idc_logistics_assign_rules WHERE id IN ('100','200')
//时间: 0.020s

我的id是主键,肯定会走索引的,那么走索引的查询应该更快啊。使用IN关键字是不走索引的,但是为什么查询要比两次主键id查询块呢?求解释。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(5

深爱不及久伴 2022-09-10 12:55:44

你这里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以后已经优化了。

半步萧音过轻尘 2022-09-10 12:55:44

我这个navicat是在最底下一排
clipboard.png

榕城若虚 2022-09-10 12:55:44

看图

差点就可以说成 到处都是

橘香 2022-09-10 12:55:44

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

分分钟 2022-09-10 12:55:44

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

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文