mysql 通配符导致查询慢

数据库订单表中有个订单编号字段order_id,varchar类型, 有索引,订单表有36W数据。

使用select * from t_order where order_id like 'DT%',查询时间只有0.03秒,查出几万条数据。

使用select * from t_order where order_id like 'W_XF%', 查询需要0.6秒,查出66条数据。

差了1个数量级,不正常。

explain查看,都是使用到索引。

百思不得姐,最后同事提醒,下划线是通配符,才想来单个下划线"_",是单个字符的通配符,难怪这么慢,所以改成如下

select * from t_order where order_id like 'W\_XF%'

速度正常。

转载于:https://my.oschina.net/purely/blog/326745

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值