Ton*_*y S 4 php pagination laravel eloquent
这是我的代码:
$prestations = Prestation::with([
'service' => function($query) {
$query->select(['id','name']);
},
'facility' => function($query) {
$query->select(['id','name']);
},
'conciergeries.network' => function($query) {
$query->select(['id','name']);
}
])
->whereHas('service', function ($query) use ($sService) {
$query->where('name', 'regexp', "/$sService/i");
})
->whereHas('facility', function ($query) use ($sPartner) {
$query->where('name', 'regexp', "/$sPartner/i");
})
->whereHas('conciergeries.network', function ($query) use ($sSubsidiary) {
$query->where('name', 'regexp', "/$sSubsidiary/i");
})
->options([
'collation' => [
'locale' => 'en_US',
'strength' => 1
]
])
->where('name', 'regexp', "/$search/i")
->orderBy($orderBy, $orderDirection)
->paginate(25);
Run Code Online (Sandbox Code Playgroud)
当我尝试获取所有 id 时:
$arrIds = [];
foreach ($prestations as $prestation) {
array_push($arrIds, $prestation->_id);
}
Run Code Online (Sandbox Code Playgroud)
问题是我只得到分页 25 个元素的 id。如何获取所有结果的 id?
您可以将查询保存在$prestationsQuery变量上并调用它两次,如下所示:
$prestationsQuery = Prestation::with([
'service:id,name',
'facility:id,name',
'conciergeries.network' => function($query) {
$query->select(['id','name']);
}
])
->whereHas('service', function ($query) use ($sService) {
$query->where('name', 'regexp', "/$sService/i");
})
->whereHas('facility', function ($query) use ($sPartner) {
$query->where('name', 'regexp', "/$sPartner/i");
})
->whereHas('conciergeries.network', function ($query) use ($sSubsidiary) {
$query->where('name', 'regexp', "/$sSubsidiary/i");
})
->options([
'collation' => [
'locale' => 'en_US',
'strength' => 1
]
])
->where('name', 'regexp', "/$search/i")
->orderBy($orderBy, $orderDirection);
$arrIds = $prestationsQuery->pluck('_id');
$prestations = $prestationsQuery->paginate(25);
Run Code Online (Sandbox Code Playgroud)
paginate记得之后打电话pluck。
另一种方法是使用tap这样的函数:
$arrIds = [];
$prestations = Prestation::with([
'service:id,name',
'facility:id,name',
'conciergeries.network' => function($query) {
$query->select(['id','name']);
}
])
->whereHas('service', function ($query) use ($sService) {
$query->where('name', 'regexp', "/$sService/i");
})
->whereHas('facility', function ($query) use ($sPartner) {
$query->where('name', 'regexp', "/$sPartner/i");
})
->whereHas('conciergeries.network', function ($query) use ($sSubsidiary) {
$query->where('name', 'regexp', "/$sSubsidiary/i");
})
->options([
'collation' => [
'locale' => 'en_US',
'strength' => 1
]
])
->where('name', 'regexp', "/$search/i")
->orderBy($orderBy, $orderDirection);
->tap(function ($query) use (&$arrIds) {
$arrIds = $query->pluck('_id');
})
->paginate(25);
Run Code Online (Sandbox Code Playgroud)