這篇文章主要介紹laravel查詢不再需要寫大量if else判斷的示例分析,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
創新互聯建站是一家專注于成都網站制作、成都網站設計、外貿營銷網站建設與策劃設計,蓬江網站建設哪家好?創新互聯建站做網站,專注于網站建設十載,網設計領域的專業建站公司;建站業務涵蓋:蓬江等地區。蓬江做網站價格咨詢:18982081108
公司主要業務使用是的PHP 語言開發,用的laravel 框架,在做一些列表過濾查詢常常會出現如下很難維護的代碼:
//若干代碼 根據參數執行不同where if (request('has_score')) { $article = $article->with(['scores' => function ($query) { $query->where('type', self::TYPE); $query->with('user'); }]); } if (has_module('Audit')) { $article = $article->with(['auditing' => function ($query) { $query->orderBy('id', 'desc'); }]); } $article = $article->with(['videos' => function ($query) { $query->where('type', VIDEO); }])->with(['audios' => function ($query) { $ query->where('type', AUDIO); }]);
如果可以將這些查詢進行配置起來,根據配置來查詢數據,而不是在代碼中直接通過if來判斷,這樣代碼會優雅一些。我自己開發一個服務包laravel-query-builder。
laravel-query-builder 是laravel框架根據已有配置來執行查詢條件構造器服務包
composer require zyimm/laravelquery-builder
{ "require": { "php": ">=7.0", "fideloper/proxy": "^4.0", "laravel/framework": ">=5.5" } }
/** // 目前支持條件操作符 '=', '<>', '>', '>=', '<', '<=', 'like', 'full_like', 'in', 'not_in', 'between', 'not_between' **/ use Illuminate\Support\Facades\DB; use zyimm\query\build\QueryWhere; /** * @var QueryWhere $build */ $build = app('QueryWhere'); //提交過來數據 $data = [ 'log_id' => 20, 'user_id'=> 'zyimm', 'user_name' => "zyimm,12" ]; //配置數據庫字段查詢操作 $condition =[ '=' => [ 'log_id' ], 'not_in' => [ 'user_id' ], 'between' => [ 'user_name' ], 'full_like' => [ 'user_id' ], '<>' => [ 'user_id' ], '>' => [ 'user_id' ] ]; DB::enableQueryLog(); //model \App\Models\Log::query() ->where(function ($query) use ($build, $data, $condition){ $build->buildQueryWhere($data ,$condition, $query); })->get(); dd(DB::getQueryLog());
提示: 'in','not_in','between','not_between'
這些標識符支持數組和字
符串,字符串可選 ','和'.'作為分隔符。
以上是“laravel查詢不再需要寫大量if else判斷的示例分析”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注創新互聯行業資訊頻道!
分享名稱:laravel查詢不再需要寫大量ifelse判斷的示例分析
本文地址:http://vcdvsql.cn/article2/pejioc.html
成都網站建設公司_創新互聯,為您提供電子商務、ChatGPT、面包屑導航、網站營銷、營銷型網站建設、
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯