mysql or_MySQL OR与IN性能

我需要确切地知道这一点,所以我对这两种方法进行了基准测试。我一致发现IN比使用OR.

不要相信那些给出他们的“意见”的人,科学都是关于检验和证据的。

我运行了一个1000倍的等价查询循环(为了一致性,我使用了sql_no_cache):

IN:2.34969592094 s

OR:5.83781504631 s

最新情况:

(与6年前一样,我没有原始测试的源代码,尽管它返回的结果与此测试的范围相同)

在请求一些示例代码来测试这一点时,下面是最简单的用例。使用雄辩的语法简单,原始SQL等效执行同样的。$t = microtime(true); for($i=0; $i<10000; $i++):$q = DB::table('users')->where('id',1)

->orWhere('id',2)

->orWhere('id',3)

->orWhere('id',4)

->orWhere('id',5)

->orWhere('id',6)

->orWhere('id',7)

->orWhere('id',8)

->orWhere('id',9)

->orWhere('id',10)

->orWhere('id',11)

->orWhere('id',12)

->orWhere('id',13)

->orWhere('id',14)

->orWhere('id',15)

->orWhere('id',16)

->orWhere('id',17)

->orWhere('id',18)

->orWhere('id',19)

->orWhere('id',20)->get();endfor;$t2 = microtime(true); echo $t."\n".$t2."\n".($t2-$t)."\n";1482080514.3635

1482080517.3713

3.0078368186951$t = microtime(true); for($i=0; $i<10000; $i++): $q = DB::table('users')->whereIn('id',[1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20])

->get(); endfor; $t2 = microtime(true); echo $t."\n".$t2."\n".($t2-$t)."\n";1482080534.0185

1482080536.178

2.1595389842987

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值