第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

這種雄辯方法的查詢范圍?

這種雄辯方法的查詢范圍?

PHP
慕尼黑8549860 2023-08-06 15:39:13
我在我的項(xiàng)目中創(chuàng)建了一個(gè)過濾方法,我使用此方法過濾了數(shù)據(jù),但現(xiàn)在我想使用 laravel 中的 queryScope 方法重構(gòu)代碼,任何人都可以建議我如何重構(gòu)此代碼。這段代碼運(yùn)行良好。這是我的控制器索引方法    public function index(Request $request)    {        $status = Ticket_status::pluck('name');        $tickets = Ticket::with('users','ticketStatus','ticketType','tbl_contacts')                    ->where('user_id','=',Auth::user()->id)                    ->latest();        if (request('Open')) {            $tickets = $tickets->where('status_id',1)->get();        } elseif (request('Pending')) {            $tickets = $tickets->where('status_id',2)->get();        } elseif (request('Close')) {            $tickets = $tickets->where('status_id',3)->get();        } else {            $tickets = $tickets->get();        }        return view('ticketing.user.index',compact('tickets','status'));    }這是我的刀片文件..在這個(gè)文件中,所有代碼都運(yùn)行良好,但我想進(jìn)行一些重構(gòu)<div class="col-md-8">                            <a                                href="{{route('tickets.index')}}"                                class="btn btn-sm btn-outline-secondary mr-1">                                All                            </a>                            @foreach ($status as $status_name)                                <a                    href="/tickets?{{Str::lower($status_name)}}={{ Str::lower($status_name) }}"                     class="btn btn-sm btn-outline-secondary mr-1">                                    {{$status_name}}                                </a>                            @endforeach                          </div>
查看完整描述

1 回答

?
Helenr

TA貢獻(xiàn)1780條經(jīng)驗(yàn) 獲得超4個(gè)贊

您可以local在模型上定義范圍來重構(gòu)查詢。以下是一些:


class Ticket extends Model

{

use SoftDeletes;


public function scopeByAuthUser($query)

{

    return $query->where('user_id','=', \Auth::user()->id);

}


public function scopeOpen($query)

{

    return $query->where('status_id', 1);

}


public function scopePending($query)

{

    return $query->where('status_id', 2);

}


public function scopeClose($query)

{

    return $query->where('status_id', 2);

}



 

}

以下是重構(gòu)您的條件的方法:


 // for the first query

 $tickets = Ticket::with('users','ticketStatus','ticketType','tbl_contacts')

                ->byAuthUser()

                ->latest();


 if(request('Open') || request('Pending') || request('Close')) {

   $scope = strtolower(request('Open') ?? request('Pending') ?? request('Close'));

   $tickets = $tickets->{$scope}()->get();

 } else {

  $tickets = $tickets->get();

 }


查看完整回答
反對(duì) 回復(fù) 2023-08-06
  • 1 回答
  • 0 關(guān)注
  • 100 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)