如何优化查询逻辑?

发布于 2022-09-01 15:38:46 字数 587 浏览 10 评论 0

看如下代码:

php$bankroll = $this->sgoods_bankroll->order('sb_id desc')->limit(50)->select();
foreach ($bankroll as $k=>&$v) {
    $sl_id = $this->bankrollpop_relations->where(array('br_sb_id'=>$v['sb_id']))->getField('br_sl_id');
    $v['dang_name'] = $this->settlementpop_list->where(array('sl_id'=>$sl_id))->getField('sl_schedule_name');
}

首先查询一个列表,然后foreach这个列表每条记录,再执行两次查询,一次去relations关联表找另一个表的关联字段,一次根据这个关联字段查询表另一个字段。

如果每次foreach查两次数据库的话,那整个下来不是查几百次数据库,这样是不是效率很低,一般这种情况可以怎么优化查询逻辑?

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

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

发布评论

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

评论(1

静水深流 2022-09-08 15:38:46

有个办法就是先foreach一遍得到所有的ids,去relations表一次查出关联的其他表的id,再根据这些id去查询一次,得到一个数组,再foreach数组拼装数据,细节不好描述,大致过程就是这样,不知道这样好不好。大家开发遇到这类问题怎么优化的?

继续补充

$sb_ids = $this->sgoods_bankroll->order('sb_id desc')->limit(50)->getField('sb_id',true);
$sb_ids = implode(',',$sb_ids);//所有sb_id

$where['br_sb_id'] = array('in',$sb_ids);
$sl_ids_array = $this->bankrollpop_relations->where($where)->getField('br_sb_id,br_sl_id');//sb_id和sl_id关联数组
$sl_ids = implode(',',$sl_ids_array);//所有sl_id

$where['sl_id'] = array('in',$sl_ids);
$sl_list = $this->settlementpop_list->where($where)->getField('sl_id,sl_schedule_name,sl_status');

$bankroll = $this->sgoods_bankroll->order('sb_id desc')->limit(50)->select();
foreach ($bankroll as $k=>&$v) {
    $sl_id = $sl_ids_array[$v['sb_id']];
    if($sl_id){
        $v['sl_schedule_name'] = $sl_list[$sl_id]['sl_schedule_name'];
        $v['sl_status'] = $sl_list[$sl_id]['sl_status'];
    }
}

优化之后提高百倍!正好记录一篇博客:http://www.tantengvip.com/2015/07/relation-mysql/

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