面向未来_ 2021-10-26 14:23 采纳率: 0%
浏览 28

mysql 查询效率问题请教一下


 SELECT MAX(temperature),MIN(temperature),  HOUR(create_time) time  from par_rdm 
where date(create_time) = '2021-10-25' AND deviceCode='RDM_FS_01'    GROUP BY time;

 SELECT MAX(temperature),MIN(temperature),  HOUR(create_time) time  from par_rdm 
where create_time like '2021-10-25%' AND deviceCode='RDM_FS_01'    GROUP BY time;

上面这两SQL 语句,where 的写法不一样,效率上哪个更高?为什么?

  • 写回答

3条回答 默认 最新

  • 南方航空 2021-10-26 14:27
    关注
    
    显然第二种写法效率更高,第二种只涉及字符串的匹配,而第一种需要用date函数将时间戳进行格式转换,需要计算花费时间
    
    评论
  • ESinker 2021-10-26 14:30
    关注

    建议去看看执行计划,如果create_time 没有索引,时间差不多,如果有索引,mysql 版本又是比较低的话 用函数那个不走索引也就是第一个会慢。第二个会快。如果两个执行计划一模一样,时间差不多的。

    评论
  • 老紫竹 2021-10-26 15:02
    关注

    都不高,你为啥不用between 之类的呢?
    where create_time >'2021-10-25' and create_time <='2021-10-25 23:59:59'

    评论

报告相同问题?

问题事件

  • 创建了问题 10月26日

悬赏问题

  • ¥15 Java中import为灰色
  • ¥15 手机等其他智能设备被监听
  • ¥15 在win10 64位的vs打包MSI文件,放到win7 64位上安装成可执行exe文件后,点击程序不运行。
  • ¥50 大众点评用户浏览/消费记录爬虫
  • ¥15 求制作一个个人网页,
  • ¥15 寻涂色内存脚本作者有项目有市场有资源.却技术
  • ¥15 蓝桥杯c51单片机问题
  • ¥15 ajax跨域问题请求修改代码
  • ¥15 python matplotlib
  • ¥15 短信测压+语音,有偿,必须用Python