use*_*178 6 php laravel eloquent laravel-4
目前,我有这个whereHas我的模型的集合:
$query = self::whereHas('club', function($q) use ($search)
{
$q->whereHas('owner', function($q) use ($search)
{
$q->where('name', 'LIKE', '%'. $search .'%');
});
});
Run Code Online (Sandbox Code Playgroud)
我的印象是上面的代码可能是这样的:
$query = self::whereHas('club.owner', function($q) use ($search)
{
$q->where('name', 'LIKE', '%'. $search .'%');
});
Run Code Online (Sandbox Code Playgroud)
我知道这已经有了很大的力量,但即便如此,如果我有5层深度的嵌套关系,事情就会变得难看.
更新:
正如评论中所述,我最终没有明白我的问题,我道歉.
我将尝试使用一个简单的例子,考虑一下$owner->club->membership->product->package
,现在我想搜索某个包的所有者,它会是这样的:
$query = self::whereHas('club', function($q) use ($search)
{
$q->whereHas('membership', function($q) use ($search)
{
$q->whereHas('product', function($q) use ($search)
{
$q->whereHas('package', function($q) use ($search)
{
$q->where('alias', 'LIKE', '%'. $search .'%');
});//package
});//product
});//membership
});//club
Run Code Online (Sandbox Code Playgroud)
它是否正确?有捷径吗?
Jar*_*zyk 29
更新:PR刚刚合并到4.2,所以现在可以在方法( )中使用点嵌套表示法has
->has('relation1.relation2)
->whereHas('relation1.relation2, ..
您的问题仍然有点不清楚,或者您误解了WhereHas()方法,因为它用于过滤模型(在这种情况下是用户)并且只获得那些具有适合搜索条件的相关模型的方法.
您似乎想要从给定用户的上下文中查找Packages,因此不需要使用whereHas方法.
无论如何,取决于关系(1-1,1-m,mm),这可以是容易的或非常困难并且不是非常有效.正如我所说的,加载嵌套关系意味着对于每个嵌套级别都会出现另一个db查询,因此在这种情况下,最终会得到5个查询.
无论关系如何,你都可以像这样反转这个链,因为它会更容易:
编辑:这不会起作用atmHas()不处理点嵌套关系!
// given $user and $search:
$packages = Package::where('alias','like',"%$search%")
->whereHas('product.membership.club.user', function ($q) use ($user) {
$q->whereId($user->id);
})->get();
Run Code Online (Sandbox Code Playgroud)
正如您所看到的,它更具可读性,仍可运行5个查询.这样你就可以获得$ packages,这是你想要的模型的单个集合.
从用户的上下文中,你会得到类似的东西(取决于关系):
$user
|-club
| |-membership
| | |-product
| | | |-packages
| | |-anotherProduct
| | | |-packages
| | |-yetAnotherProduct
| | |-packages
| |-anotherMembership
.....
Run Code Online (Sandbox Code Playgroud)
你明白了,不是吗?
你可以从Collection中获取包,但这会很麻烦.反过来说比较容易.
所以你的问题的答案就是加入表格:
// Let's assume the relations are the easiest to handle: 1-many
$packages = Package::where('alias','like',"%$search%")
->join('products','packages.product_id','=','products.id')
->join('memberships','products.membership_id','=','memberships.id')
->join('clubs','memberships.club_id','=','clubs.id')
->where('clubs.user_id','=',$user->id)
->get(['packages.*']); // dont select anything but packages table
Run Code Online (Sandbox Code Playgroud)
当然,您可以将它包装在一个很好的方法中,这样您每次执行此类搜索时都不必编写它.此查询的性能肯定比上面显示的单独的5个查询要好得多.显然,这种方式只加载包,没有其他相关模型.
归档时间: |
|
查看次数: |
15314 次 |
最近记录: |