mysql 性能优化,减轻数据库的压力。(减少数据库查询的次数)

查询订单相应的user_id的详细

$arr = array(
        1=>array(
                'user_id' => 5,
                'good_id' => '361'
        ),
        2=>array(
                'user_id' => 63,
                'good_id' => '3663'
        ),
        3=>array(
                'user_id' => 75,
                'good_id' => '3663'
        ),
);

我们习惯性:使用 foreach 遍历数据,select 查询一条数据,然后放在新的数组,但是你想想每次遍历一次就查询一次数据库,增加了数据库的压力,按照性能来说这样不可取的。

最优方式:我们可以把所有的user_id拿出来,然后mysql使用 in 方式一次性查询数据,这样减轻数据库的压力

$arr2 = array_column($arr, 'user_id');

结果:

$arr2 = array(

        0=>5,

       1=>63,

       3=>75

);

$arr3=implode(',',$arr2);

结果 5,63,75

select * from user where id in ($arr);

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值