Laravel框架查詢(xún)構(gòu)造器常見(jiàn)用法總結(jié)
本文實(shí)例講述了Laravel框架查詢(xún)構(gòu)造器常見(jiàn)用法。分享給大家供大家參考,具體如下:
查詢(xún)構(gòu)造器也是我們使用laravel框架的一項(xiàng)必備技能,上一篇文章我們講到了如何使用原生增刪改查,這一篇我們就來(lái)講查詢(xún)構(gòu)造器的增刪改查(以下知識(shí)點(diǎn)若有不全面的地方,還請(qǐng)多多諒解)
查詢(xún)構(gòu)造器簡(jiǎn)介:
Laravel查詢(xún)構(gòu)造器提供方便流暢的接口,用來(lái)建立及執(zhí)行數(shù)據(jù)庫(kù)查找語(yǔ)法
使用PDO參數(shù)綁定,以保護(hù)應(yīng)用程序免于SQL注入因此傳入的參數(shù)不需要額外轉(zhuǎn)移特殊字符
基本可以滿足所有數(shù)據(jù)庫(kù)操作,而且在所有支持的數(shù)據(jù)庫(kù)系統(tǒng)上都可以執(zhí)行
NO.1查詢(xún)構(gòu)造器新增數(shù)據(jù)
1.最基本的新增
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur1() { $bool = DB::table('student')//table指的是一個(gè)數(shù)據(jù)表,而括號(hào)里的('student')則指的是一個(gè)名為student的數(shù)據(jù)表 ->insert( ['name' => 'Rarin','age' =>16] ); echo "<pre>"; print_r($bool); echo "</pre>"; } }
ok,然后他會(huì)返回一個(gè)數(shù)字“1”,返回?cái)?shù)字“1”則證明他已經(jīng)新建了一條數(shù)據(jù)。
2.獲取一個(gè)新增的數(shù)據(jù)id
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur1() { $bool = DB::table('student') ->insertGetId( ['name'=>'Shen' , 'age'=>'16'] ); echo "<pre>"; print_r($bool); echo "</pre>"; } }
然后他會(huì)彈出相對(duì)應(yīng)的id值,我的id值是2,所以他會(huì)顯示一個(gè)數(shù)字“2”。
3.新增多條數(shù)據(jù)
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur1() { $bool = DB::table('student') ->insert([ ['name'=>'Chen','age'=>18], ['name'=>'He','age'=>16] ]); var_dump($bool); } }
為了和上面的區(qū)分一下,我把print_r換成了var_dump,他會(huì)輸出成一個(gè)true,證明新增成功了。
NO.2查詢(xún)構(gòu)造器修改數(shù)據(jù)
1.修改一條數(shù)據(jù)
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur2() { $upt = DB::table('student') ->where('id',3) ->update(['age'=>20]); echo "<pre>"; print_r($upt); echo "</pre>"; } }
那么,他會(huì)輸出一個(gè)數(shù)字1,代表的是影響的行數(shù)是一行。
2.自增某條數(shù)據(jù)
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur2() { $upt = DB::table('student') ->increment('age'); echo "<pre>"; print_r($upt); echo "</pre>"; } }
結(jié)果,他會(huì)輸出為4,因?yàn)槲乙还灿兴男袛?shù)據(jù),所以他影響到了四行數(shù)據(jù),自增了1(在這里要說(shuō)明一下,沒(méi)有給他賦值的時(shí)候他默認(rèn)值為1)
那么我們又要如何給他附上值呢?代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur2() { $upt = DB::table('student') ->increment('age',2);//在這里,我們指定他自增的值為2 echo "<pre>"; print_r($upt); echo "</pre>"; } }
那么,他輸出的值照樣是4,證明影響了四個(gè)行數(shù),然后去查看的時(shí)候,可以發(fā)現(xiàn)每個(gè)數(shù)據(jù)的年齡都大了2歲
3.自減某條數(shù)據(jù)
自減的默認(rèn)值和設(shè)置值的操作步驟與自增一致,唯一不同的就是關(guān)鍵字從increment轉(zhuǎn)換成了decrement。
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur2() { $upt = DB::table('student') ->decrement('age'); echo "<pre>"; print_r($upt); echo "</pre>"; } }
然后他會(huì)返回一個(gè)受影響行數(shù)的值,我這里有四個(gè)行數(shù)受到了影響,所以返回4
4.根據(jù)某個(gè)條件進(jìn)行自增(自減同理)
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur2() { $upt = DB::table('student') ->where('id',1) ->increment('age'); echo "<pre>"; print_r($upt); echo "</pre>"; } }
因?yàn)槭苡绊懙臄?shù)據(jù)只有id是為1的數(shù)據(jù),所以他會(huì)返回?cái)?shù)字1,證明受影響的行數(shù)只有一行,自減同理,不過(guò)多介紹
自減的時(shí)候修改其他字段(自增同理)
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur2() { $upt = DB::table('student') ->where('id',3) ->decrement('age',3,['name' => 'ChenChai']); echo "<pre>"; print_r($upt); echo "</pre>"; } }
他會(huì)返回一個(gè)受影響的行數(shù)值
NO.3查詢(xún)構(gòu)造器刪除數(shù)據(jù)
1.刪除某條數(shù)據(jù)
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur3() { $dlt = DB::table('student') ->where('id',4)//當(dāng)id為4的時(shí)候 ->delete(); echo "<pre>"; print_r($dlt); echo "</pre>"; } }
他會(huì)返回一個(gè)數(shù)字1,表示刪除的數(shù)據(jù)共有1行。
2.根據(jù)某個(gè)值刪除多條數(shù)據(jù)
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur3() { $dlt = DB::table('student') ->where('id','>=',2)//當(dāng)id大于等于2的時(shí)候 ->delete(); echo "<pre>"; print_r($dlt); echo "</pre>"; } }
他會(huì)輸出相對(duì)應(yīng)被刪除幾條數(shù)據(jù)的數(shù)字,我這里刪除了2條數(shù)據(jù),所以他返回一個(gè)2
NO.4查詢(xún)構(gòu)造器查詢(xún)數(shù)據(jù)
1.get方式獲取所有的數(shù)據(jù)
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur4() { $slt = DB::table('student') ->get(); dd($slt); } }
2.first方式
獲取第一條數(shù)據(jù)
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur4() { $slt = DB::table('student') ->first(); dd($slt); } }
顯示的結(jié)果如下:
重新排序
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur4() { $slt = DB::table('student') ->orderBy('id','desc') ->first(); dd($slt); } }
結(jié)果如下:
數(shù)據(jù)表如下:
3.where方式
插入一條數(shù)據(jù)
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur4() { $slt = DB::table('student') ->where('id','>',1)//當(dāng)id大于1的時(shí)候 ->get(); dd($slt); } }
結(jié)果如下:
插入多條數(shù)據(jù)
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur4() { $slt = DB::table('student') ->whereRaw('id > ? and age = ?',[1,19])//當(dāng)id大于1的時(shí)候,并且age等于191的時(shí)候 ->get(); dd($slt); } }
4.pluck方式
他只返回某個(gè)值,以數(shù)組的形式
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur4() { $slt = DB::table('student') ->pluck('name'); dd($slt); } }
結(jié)果如下:
5.lists方式
作用和pluck方式差不多,但唯一不同的就是,他可以指定返回的下標(biāo)是多少
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur4() { $slt = DB::table('student') ->lists('name','id');//指定返回的下標(biāo)是和name相對(duì)應(yīng)的id dd($slt); } }
6.select方式
你可以用它指定輸出相對(duì)應(yīng)的值,而不會(huì)像get方式一樣把所有無(wú)關(guān)緊要的值也輸出出來(lái)
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur4() { $slt = DB::table('student') ->select('name','id','age') ->get(); dd($slt); } }
結(jié)果不做多介紹,只要簡(jiǎn)單的理解為指定查找即可
7.chunk方式
這個(gè)一般是用在數(shù)據(jù)過(guò)多的時(shí)候,為了流暢,設(shè)定每次輸出多少條數(shù)據(jù)
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur4() { DB::table('student') ->chunk(1,function($slt){ echo "<pre>"; print_r($slt); echo "</pre>"; }); } }
如果你只需要查詢(xún)一次,只需要添加一個(gè)return false即可。
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur4() { DB::table('student') ->chunk(1,function($slt){ echo "<pre>"; print_r($slt); echo "</pre>"; return false; }); } }
但是一般這種情況都是你滿足了某個(gè)條件后就不再執(zhí)行,所以我們往匿名函數(shù)里增加一個(gè)if判斷語(yǔ)句來(lái)判斷再return即可
NO.5查詢(xún)構(gòu)造器聚合函數(shù)
1.count函數(shù)
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur5() { $num = DB::table('student') ->count(); print_r($num); } }
他這個(gè)函數(shù)是輸出數(shù)據(jù)有幾條記錄,我這里數(shù)據(jù)有2條記錄,所以他會(huì)輸出一個(gè)2
2.max函數(shù)
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur5() { $num = DB::table('student') ->max('age'); print_r($num); } }
返回?cái)?shù)據(jù)里某個(gè)數(shù)據(jù)的最大值
3.min函數(shù)
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur5() { $num = DB::table('student') ->min('age'); print_r($num); } }
與max同理
4.avg函數(shù)
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur5() { $num = DB::table('student') ->avg('age'); print_r($num); } }
返回年齡的平均值
5.sum函數(shù)
代碼如下:
namespace App\Http\Controllers; use Illuminate\Support\Facades\DB; class SController extends Controller { public function qur5() { $num = DB::table('student') ->sum('age'); print_r($num); } }
返回?cái)?shù)據(jù)里某個(gè)數(shù)據(jù)的總和
更多關(guān)于Laravel相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《Laravel框架入門(mén)與進(jìn)階教程》、《php優(yōu)秀開(kāi)發(fā)框架總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門(mén)教程》、《php+mysql數(shù)據(jù)庫(kù)操作入門(mén)教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家基于Laravel框架的PHP程序設(shè)計(jì)有所幫助。
- laravel技巧之查詢(xún)構(gòu)造器Query Builder疊加鏈?zhǔn)秸{(diào)用的方法
- 使用Laravel中的查詢(xún)構(gòu)造器實(shí)現(xiàn)增刪改查功能
- 解決laravel查詢(xún)構(gòu)造器中的別名問(wèn)題
- Laravel框架查詢(xún)構(gòu)造器簡(jiǎn)單示例
- Laravel框架查詢(xún)構(gòu)造器 CURD操作示例
- Laravel 使用查詢(xún)構(gòu)造器配合原生sql語(yǔ)句查詢(xún)的例子
- Laravel5中實(shí)現(xiàn)模糊匹配加多條件查詢(xún)功能的方法
- 在Laravel5.6中使用Swoole的協(xié)程數(shù)據(jù)庫(kù)查詢(xún)
- laravel實(shí)現(xiàn)查詢(xún)最后執(zhí)行的一條sql語(yǔ)句的方法
- Laravel Eloquent ORM 實(shí)現(xiàn)查詢(xún)表中指定的字段
相關(guān)文章
php類(lèi)中的$this,static,final,const,self這幾個(gè)關(guān)鍵字使用方法
php類(lèi)中的$this,static,final,const,self這幾個(gè)關(guān)鍵字在項(xiàng)目中經(jīng)常會(huì)用的到,通過(guò)本文給大家分享this,static,final,const,self這幾個(gè)關(guān)鍵字使用方法,對(duì)此感興趣的朋友一起學(xué)習(xí)吧2015-12-12php模板引擎技術(shù)簡(jiǎn)單實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了php模板引擎技術(shù)簡(jiǎn)單實(shí)現(xiàn),感興趣的小伙伴們可以參考一下2016-03-03thinkphp框架page類(lèi)與bootstrap分頁(yè)(美化)
這篇文章主要介紹了thinkphp框架page類(lèi)與bootstrap分頁(yè)(美化) ,需要的朋友可以參考下2017-06-06ajax實(shí)現(xiàn)無(wú)刷新分頁(yè)(php)
直接給出源代碼,可自行分析,寫(xiě)的不好請(qǐng)留言指正,謝謝!2010-07-07PHP中針對(duì)區(qū)域語(yǔ)言標(biāo)記信息的操作
大家都知道Locale 類(lèi)就是操作區(qū)域語(yǔ)言相關(guān)內(nèi)容的,它無(wú)法被實(shí)例化,所有全部功能方法都是靜態(tài)的。接下來(lái)通過(guò)本文給大家分享PHP中針對(duì)區(qū)域語(yǔ)言標(biāo)記信息的操作,需要的朋友參考下吧2021-07-07laravel7學(xué)習(xí)之無(wú)限級(jí)分類(lèi)的最新實(shí)現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于laravel7學(xué)習(xí)之無(wú)限級(jí)分類(lèi)的最新實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09PHP中__set()實(shí)例用法和基礎(chǔ)講解
在本篇文章里小編給大家整理了關(guān)于HP中__set()實(shí)例用法和基礎(chǔ)講解,對(duì)此有需要的朋友們可以學(xué)習(xí)參考下。2019-07-07yii2使用ajax返回json的實(shí)現(xiàn)方法
這篇文章主要介紹了yii2使用ajax返回json的實(shí)現(xiàn)方法,實(shí)例分析了Yii框架使用ajax調(diào)用數(shù)據(jù)及返回json格式數(shù)據(jù)的相關(guān)技巧,需要的朋友可以參考下2016-05-05