- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在尝试在 Laravel 中创建我的第一个项目。我有表 urls
和 reviews
,每个 url 都有很多评论。在索引 View 中,我想列出所有 url 及其最新的 2 条评论。
模型网址
public function reviews()
{
return $this->hasMany('App\Review');
}
模型审核
public function url()
{
return $this->belongsTo('App\Url');
}
类 UrlController
class UrlController extends Controller
{
public function index()
{
// here I would need to get all urls with latest two reviews for each url
$urls = URL::all();
return view('urls.index')->with('urls', $urls);
}
}
查看索引
@foreach ($urls as $url)
<li>
// Echo url name
{{ $url->url }}
// Here I need to list 2 reviews
// Something like...
@foreach ($url->reviews as $review)
$review->text
@endforeach
</li>
@endforeach
我的代码通常设置正确吗?
1.try - UrlController 中的这段代码适用于 url,而不是它的评论。
$urls = URL::with('reviews')->orderBy('created_at')->take(2)->get();
2.尝试此代码将限制所有获取评论的数量,在这种情况下,只有第一个 url 会收到评论,而其他 url 将为零。
$urls = URL::with([
'reviews' => function($q){
$q->orderBy('created_at', 'asc');
$q->limit(2);
}
])->get();
最佳答案
在您的模型中添加范围:
public function scopeLatestFirst($query)
{
return $query->orderBy('created_at', 'asc')->limit(2);
}
然后调用:
@foreach ($url->reviews()->latestFirst()->get() as $review)
$review->text
@endforeach
More about scopes
关于php - 获取数据行但相关表行数有限,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41039498/
我有一个关于复杂性的简单问题。我在 Java 中有这段代码: pairs是 HashMap包含 Integer作为键,它的频率为 Collection作为一个值。所以: pairs = new Has
对于我的应用程序,我需要在 Coq 中使用和推理有限映射。谷歌搜索我发现 FMapAVL 似乎非常适合我的需求。问题是文档很少,我还没有弄清楚我应该如何使用它。 作为一个简单的例子,考虑以下使用对列表
我有一个主表tblAssetMaster A和一个移动表tblMovement M。 我想提取所有 Assets 及其当前位置,因此需要获取每个 Assets 的最新移动条目。 字段 A: Asset
我想让我的网站内容居中,但仅限于网页的特定宽度。所以当它超过 500px 时,我希望内容被修复,无法进一步拉伸(stretch)。无论如何都要这样做,还是我最好把所有东西都修好?希望有意义的是添加一些
我正在尝试批量删除 Backbone 模型的集合,如下所示...... collection.each(function(model, i){ model.destroy(); }); 我发现当每
我想要一个软件环境,在其中我可以在具有特定资源的硬件上测试我的软件的速度。例如,当我的主机硬件是具有 12GB RAM 的 3GHz 四核 amd64 时,该程序在具有 24 Mb RAM 的 800
在 Eclipse 中,我得到了 BigInteger.valueOf(2).pow(31093) 的值,但没有得到 BigInteger.valueOf(2).pow(31094) 的值(它是空的)
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求提供代码的问题必须表现出对所解决问题的最低限度理解。包括尝试过的解决方案、为什么它们不起作用,以及预
我想将 2 个表从本地 sql server 2000 上传到托管的 mysql。第一个表有 17 列和 680 行,其他 10 列和 8071 行。 我首先使用 xampp mysql 尝试离线,它
我在 S3 中自动生成并保存了静态 html 文件。有时文件大小达到 2mb。是否可以使用javascript来获取html文件的一部分,显示它,当用户到达页面底部时,获取下一部分等等? 最佳答案 X
我是一名优秀的程序员,十分优秀!