2016-06-16 7 views
1

Я пытаюсь сделать вложенный поисковый запрос, но я получаю эту ошибку. Я пытаюсь найти название компании, к которой присоединился company_id.Laravel 5 вложенный поисковый запрос

SQLSTATE[42S22]: Column not found: 1054 Unknown column 'company.name' in 'where clause' (SQL: select count(*) as aggregate from `position` where `to_date` >= 2016-06-16 and `company_id` = 123795854693734 and `title` like %searchquery% and `company`.`name` like %searchquery% and `location` like %%) 

Вот моя функция

public function Search(){ 

    $keyword = Input::get('q'); 
    $location = Input::get('l'); 

    $data = Position::where('to_date', '>=', date('Y-m-d')) 
    ->where('company_id', '=', $company_id) 
    ->where('title', 'like', '%'.$keyword.'%') 
    ->where('company.name', 'like', '%'.$keyword.'%') 
    ->where('location', 'like', '%'.$location.'%') 
    ->orderBy('from_date', 'desc') 
    ->paginate(10); 

    $data = array(
     'data' => $data, 
    ); 

    return view('myview', $data); 

} 

контроллер Модель работает отлично. Но здесь все равно.

namespace App; 
use Illuminate\Database\Eloquent\Model; 

class Position extends Model { 
    protected $table = 'position'; 
    protected $guarded = array("id"); 
    protected $hidden = array(); 
    protected $appends = array('local_ad'); 

    protected $fillable = ['title', 'company_id', 'location']; 

    public function company() { 
     return $this->belongsTo('App\Company', 'company_id', 'id'); 
    } 

} 
+0

Не слишком знакомы с Laravel, но ошибка и код предполагают, что вам не хватает соединения с таблицей компании. – Oldskool

ответ

2

На самом деле вы не используете свое отношение или не присоединяетесь к столу компании, поэтому он не может его найти.

Просто вы можете использовать метод whereHas для фильтрации позиций с названиями компаний.

$data = Position::whereHas('company', function ($q) use ($keyword) { 
    $q->where('name', 'like', '%'.$keyword.'%'); 
})->where('to_date', '>=', date('Y-m-d')) 
    ->where('company_id', '=', $company_id) 
    ->where('title', 'like', '%'.$keyword.'%') 
    ->where('location', 'like', '%'.$location.'%') 
    ->orderBy('from_date', 'desc') 
    ->paginate(10); 
1

Эта функция должна быть

общественная функция поиска() {

$keyword = Input::get('q'); 
$location = Input::get('l'); 

$data = Position::where('to_date', '>=', date('Y-m-d')) 
->where('company_id', '=', $company_id) 
->where('title', 'like', '%'.$keyword.'%') 
->with(['company' => function($q) use ($keyword) { 
    ->where('name', 'like', '%'.$keyword.'%') 
}]) 
->where('location', 'like', '%'.$location.'%') 
->orderBy('from_date', 'desc') 
->paginate(10); 

$data = array(
    'data' => $data, 
); 

return view('myview', $data); 

, но это не делает объединение, это будет получать позиции, есть whereHas в красноречивых, вы должны исследуйте это также.

Смежные вопросы