簡體   English   中英

如何在switch語句中使用laravel模型運行多個Where子句

[英]How to run multiple Where clauses using laravel models in a switch statement

我有一個switch語句,我想根據case clauses查詢Database 我想使用Where clauses實現我的目標。 我想基於滿足的條件向我的User模型增量添加where子句。 例如:

switch($key){
    case 'province':
        //User::where('province', '=', $value);
        break;
    case 'city':
        //User::where('city', '=', $value);
        break;
    case 'specialty':
        //User::where('specialty', '=', $value);
        break;
    default:
        break;
}

我想使用口才模型而不是查詢生成器。 但我不知道該怎么做。

這是您的操作方式:

// instantiate the query
$query = User::query();

// add wheres
switch / foreach or whatever
{
   $query->where(...);
}

// other methods if needed
$query->orderBy(..)

// execute
$users = $query->get();

如果要增量添加子句,則循環將比switch語句更好。 假設您的信息來自用戶輸入,我將這樣做:

$input = Input::only(['province', 'city', 'speciality']);
$user = new User;

foreach($input as $key => $value) {
     if(!empty($value)) {
         $user = $user->where($key, $value);
     }
}

$users = $user->get();

return View::make('foo', compact('users'));

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM