Поисковый запрос Laravel с несколькими условиями
Новичок для PHP/Laravel здесь, пожалуйста, будьте терпеливы.
У меня есть веб-страница, которая ищет по 3 критериям для собак, породы, пола и радиуса.
вот соответствующий код:
страница поиска
<div class="col-md-12 zero-pad-left zero-pad-right">
{{ Form::open(array('action' => array('[email protected]'), 'class'=>'form width88', 'role'=>'search', 'method' => 'GET')) }}
<div id="prefetch">
{{ Form::text('search-breed', null, array('class' => 'typeahead form-group form-control', 'placeholder' => 'Search by breed here...')) }}
{{ Form::text('sex', null, array('class' => 'form-group form-control', 'placeholder' => 'Search by sex here...')) }}
{{ Form::text('miles', null, array('class' => 'form-group form-control', 'placeholder' => 'Search by distance here...')) }}
</div>
{{ Form::submit('Search', array('class' => 'btn btn-default search-bar-btn')) }}
{{ Form::close() }}
ControllerPage
class DogsController extends \BaseController {
public function __construct()
{
// call base controller constructor
parent::__construct();
// run auth filter before all methods on this controller except index and show
$this->beforeFilter('auth', array('except' => array('show')));
}
/**
* Display a listing of the resource.
*
* @return Response
*/
public function index()
{
if (Input::has('search')) {
$queryString = Input::get('search');
$dogs = Dog::where('name', 'LIKE', "%$queryString%")->orderBy('name')->paginate(5);
}
elseif (Input::has('search-breed'))
{
$dogs = Dog::whereHas('breed', function($q)
{
$queryString = Input::get('search-breed');
$q->where('name', 'LIKE', "%$queryString%");
})->orderBy('name')->paginate(5);
} //end elseif
else {
$dogs = Dog::orderBy('name')->paginate(5);
} //end else
return View::make('dogs.index')->with(array('dogs' => $dogs));
} //end function index()
когда я вхожу в поиск пуделя, мужчина, в радиусе 20 миль, он показывает следующее:
http://ruff-love.dev/dogs?search-breed=poodle&sex=M&miles=20
Поиск в настоящее время работает нормально при поиске только породы.
Кажется, я не могу понять синтаксис, чтобы добавить критерии SEX и RADIUS. он должен допускать, чтобы эти критерии были пустыми и все еще выполняли запрос.
любой совет будет очень признателен
Ответы
Ответ 1
Вы можете использовать области запросов http://laravel.com/docs/eloquent#query-scopes, чтобы сделать это подробным и простым в своем контроллере (или где бы вы это делали в будущем), а затем связывать их в соответствии с вашими потребностями:
// Dog model
public function scopeSearchBreed($query, $breed)
{
$query->whereHas('breed', function ($q) use ($breed) {
$q->where('name', 'like', "%{$breed}%");
});
}
public function scopeWithinRadius($query, $radius)
{
$query->where(...); // do math here
}
Тогда все, что вам нужно, это:
public function index()
{
$q = Dog::query();
if (Input::has('search'))
{
// simple where here or another scope, whatever you like
$q->where('name','like',Input::get('search'));
}
if (Input::has('search-breed'))
{
$q->searchBreed(Input::get('search-breed'));
}
if (Input::has('sex'))
{
$q->where('sex', Input::get('sex'));
}
if (Input::has('radius'))
{
$q->withinRadius(Input::get('radius'));
}
$dogs = $q->orderBy(..)->paginate(5);
// ...
Ответ 2
Вот одно из возможных решений, я думаю, что, возможно, есть и другие. Создайте пустой конструктор запросов с помощью функции query()
и добавьте к нему необязательные предложения, затем вызовите функцию paginate()
в конце.
$builder = Dogs::query();
if (Input::has('search')) {
$queryString = Input::get('search');
$builder->where('name', 'LIKE', "%$queryString%");
}
// ... more clauses from the querystring
$dogs = $builder->orderBy('name')->paginate(5);
Ответ 3
$builder = Dogs::query();
$term = Request::all();
if(!empty($term['breed'])){
$builder->where('breed','=',$term['breed']);
}
if(!empty($term['sex'])){
$builder->where('sex','=',$term['sex']);
}
if(!empty($term['radius'])){
$builder->where('radius','=',$term['radius']);
}
$result = $builder->orderBy('id')->get();