首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >拉拉从每个岗位得到最后一次投标

拉拉从每个岗位得到最后一次投标
EN

Stack Overflow用户
提问于 2016-10-30 12:45:13
回答 3查看 230关注 0票数 1

我有两个桌子,项目和出价。

项目hasMany(投标);

表项

  • id-1
  • id-2
  • id-3

表标

  • id-1 -3
  • id-1 -4
  • id-2 \x{e76f}2
  • id-2 -5
  • id-3 -4
  • id-3 -6

现在我要展示每个项目的最高出价。

这是我的密码

代码语言:javascript
复制
 $data = PostItem::with([
     'bids' => function($query) {
         $query->orderBy('new_bid','desc')->get();
     }
 ])
 ->get();

但问题是,它将采取所有的出价。

但是如果我用这个代码

代码语言:javascript
复制
 $data = PostItem::with([
     'bids' => function($query) {
          $query->orderBy('new_bid','desc')->take(1);
     }
 ])
 ->get();

它将只需要一个最新的出价,不要采取每个项目的最新出价。

如何做好呢?

提前感谢

EN

回答 3

Stack Overflow用户

发布于 2016-10-30 12:50:25

limit()添加到关系中:

代码语言:javascript
复制
public function highestBids()
{
    return $this->hasMany('App\Bid')->orderBy('new_bid', 'desc')->limit(1);
}

然后得到最高的出价:

代码语言:javascript
复制
$data = PostItem::with('highestBids')->get();
票数 1
EN

Stack Overflow用户

发布于 2016-10-30 12:58:40

您可以将查询写成:

代码语言:javascript
复制
 $items = PostItem::with(['bids' => function($query){
                    $query->orderBy('new_bid','desc');
                }])
                ->get();

现在每件物品的最高标价是:

代码语言:javascript
复制
foreach ($items as $item) {
    $highest_bid = $item->bids->first(); // highest bids of $item
    if($highest_bid) {
       $new_bid = $item->new_bid;
    }
}
票数 0
EN

Stack Overflow用户

发布于 2016-10-30 14:00:17

我有答案,但可能不是最好的答案。

因此,我仍然使用我的第一个查询,然后在视图中使用@foreach。因为我已经排序的最高出价第一,所以我添加了@break打破外汇,这样它就不会循环所有的结果。

但我相信还有更好的方法

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40329225

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档