2016-06-16 18 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があり、位置を取得しますそれも探検してください。

関連する問題