亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Laravel框架查詢構造器常見用法總結

 更新時間:2019年12月06日 11:04:26   作者:陳柴Rarin  
這篇文章主要介紹了Laravel框架查詢構造器常見用法,結合實例形式總結分析了laravel框架查詢構造器相關原理與常見使用技巧,需要的朋友可以參考下

本文實例講述了Laravel框架查詢構造器常見用法。分享給大家供大家參考,具體如下:

查詢構造器也是我們使用laravel框架的一項必備技能,上一篇文章我們講到了如何使用原生增刪改查,這一篇我們就來講查詢構造器的增刪改查(以下知識點若有不全面的地方,還請多多諒解)

查詢構造器簡介:

Laravel查詢構造器提供方便流暢的接口,用來建立及執(zhí)行數(shù)據庫查找語法
使用PDO參數(shù)綁定,以保護應用程序免于SQL注入因此傳入的參數(shù)不需要額外轉移特殊字符
基本可以滿足所有數(shù)據庫操作,而且在所有支持的數(shù)據庫系統(tǒng)上都可以執(zhí)行

NO.1查詢構造器新增數(shù)據

1.最基本的新增

代碼如下:

namespace App\Http\Controllers;
use Illuminate\Support\Facades\DB;
class SController extends Controller
{
 public function qur1()
 {
 $bool = DB::table('student')//table指的是一個數(shù)據表,而括號里的('student')則指的是一個名為student的數(shù)據表
 ->insert(
  ['name' => 'Rarin','age' =>16]
 );
 echo "<pre>";
 print_r($bool);
 echo "</pre>";
 }
}

ok,然后他會返回一個數(shù)字“1”,返回數(shù)字“1”則證明他已經新建了一條數(shù)據。

2.獲取一個新增的數(shù)據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>";
 }
}

然后他會彈出相對應的id值,我的id值是2,所以他會顯示一個數(shù)字“2”。

3.新增多條數(shù)據

代碼如下:

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,他會輸出成一個true,證明新增成功了。

NO.2查詢構造器修改數(shù)據

1.修改一條數(shù)據

代碼如下:

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>";
 }
}

那么,他會輸出一個數(shù)字1,代表的是影響的行數(shù)是一行。

2.自增某條數(shù)據

代碼如下:

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>";
 }
}

結果,他會輸出為4,因為我一共有四行數(shù)據,所以他影響到了四行數(shù)據,自增了1(在這里要說明一下,沒有給他賦值的時候他默認值為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,證明影響了四個行數(shù),然后去查看的時候,可以發(fā)現(xiàn)每個數(shù)據的年齡都大了2歲

3.自減某條數(shù)據

自減的默認值和設置值的操作步驟與自增一致,唯一不同的就是關鍵字從increment轉換成了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>";
 }
}

然后他會返回一個受影響行數(shù)的值,我這里有四個行數(shù)受到了影響,所以返回4

4.根據某個條件進行自增(自減同理)

代碼如下:

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>";
 }
}

因為受影響的數(shù)據只有id是為1的數(shù)據,所以他會返回數(shù)字1,證明受影響的行數(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>";
 }
}

他會返回一個受影響的行數(shù)值

NO.3查詢構造器刪除數(shù)據

1.刪除某條數(shù)據

代碼如下:

namespace App\Http\Controllers;
use Illuminate\Support\Facades\DB;
class SController extends Controller
{
 public function qur3()
 {
 $dlt = DB::table('student')
 ->where('id',4)//當id為4的時候
 ->delete();
 echo "<pre>";
 print_r($dlt);
 echo "</pre>";
 }
}

他會返回一個數(shù)字1,表示刪除的數(shù)據共有1行。

2.根據某個值刪除多條數(shù)據

代碼如下:

namespace App\Http\Controllers;
use Illuminate\Support\Facades\DB;
class SController extends Controller
{
 public function qur3()
 {
 $dlt = DB::table('student')
 ->where('id','>=',2)//當id大于等于2的時候
 ->delete();
 echo "<pre>";
 print_r($dlt);
 echo "</pre>";
 }
}

他會輸出相對應被刪除幾條數(shù)據的數(shù)字,我這里刪除了2條數(shù)據,所以他返回一個2

NO.4查詢構造器查詢數(shù)據

1.get方式獲取所有的數(shù)據

代碼如下:

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ù)據

代碼如下:

namespace App\Http\Controllers;
use Illuminate\Support\Facades\DB;
class SController extends Controller
{
 public function qur4()
 {
 $slt = DB::table('student')
 ->first();
 dd($slt);
 }
}

顯示的結果如下:

在這里插入圖片描述

重新排序

代碼如下:

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);
 }
}

結果如下:

在這里插入圖片描述

數(shù)據表如下:

在這里插入圖片描述

3.where方式

插入一條數(shù)據

代碼如下:

namespace App\Http\Controllers;
use Illuminate\Support\Facades\DB;
class SController extends Controller
{
 public function qur4()
 {
 $slt = DB::table('student')
 ->where('id','>',1)//當id大于1的時候
 ->get();
 dd($slt);
 }
}

結果如下:

在這里插入圖片描述

插入多條數(shù)據

代碼如下:

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])//當id大于1的時候,并且age等于191的時候
 ->get();
 dd($slt);
 }
}

4.pluck方式

他只返回某個值,以數(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);
 }
}

結果如下:

在這里插入圖片描述

5.lists方式

作用和pluck方式差不多,但唯一不同的就是,他可以指定返回的下標是多少

代碼如下:

namespace App\Http\Controllers;
use Illuminate\Support\Facades\DB;
class SController extends Controller
{
 public function qur4()
 {
 $slt = DB::table('student')
 ->lists('name','id');//指定返回的下標是和name相對應的id
 dd($slt);
 }
}

6.select方式

你可以用它指定輸出相對應的值,而不會像get方式一樣把所有無關緊要的值也輸出出來

代碼如下:

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);
 }
}

結果不做多介紹,只要簡單的理解為指定查找即可

7.chunk方式

這個一般是用在數(shù)據過多的時候,為了流暢,設定每次輸出多少條數(shù)據

代碼如下:

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即可。

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;
 });
 }
}

但是一般這種情況都是你滿足了某個條件后就不再執(zhí)行,所以我們往匿名函數(shù)里增加一個if判斷語句來判斷再return即可

NO.5查詢構造器聚合函數(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);
 }
}

他這個函數(shù)是輸出數(shù)據有幾條記錄,我這里數(shù)據有2條記錄,所以他會輸出一個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);
 }
}

返回數(shù)據里某個數(shù)據的最大值

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);
 }
}

返回數(shù)據里某個數(shù)據的總和

更多關于Laravel相關內容感興趣的讀者可查看本站專題:《Laravel框架入門與進階教程》、《php優(yōu)秀開發(fā)框架總結》、《php面向對象程序設計入門教程》、《php+mysql數(shù)據庫操作入門教程》及《php常見數(shù)據庫操作技巧匯總

希望本文所述對大家基于Laravel框架的PHP程序設計有所幫助。

相關文章

  • laravel 5.3中自定義加密服務的方案詳解

    laravel 5.3中自定義加密服務的方案詳解

    這篇文章主要給大家介紹了在laravel 5.3中自定義加密服務的相關資料,文中介紹的非常詳細,對大家學習或者使用laravel 5.3具有一定的參考學習價值,需要的朋友們下面來一起看看吧。
    2017-05-05
  • ThinkPHP3.1新特性之內容解析輸出詳解

    ThinkPHP3.1新特性之內容解析輸出詳解

    以往版本的ThinkPHP對于模板文件保存在數(shù)據庫里面的情況下,無法進行模板文件讀取的。這篇文章主要介紹了ThinkPHP3.1新特性的內容解析輸出,需要的朋友可以參考下
    2014-06-06
  • php類中的$this,static,final,const,self這幾個關鍵字使用方法

    php類中的$this,static,final,const,self這幾個關鍵字使用方法

    php類中的$this,static,final,const,self這幾個關鍵字在項目中經常會用的到,通過本文給大家分享this,static,final,const,self這幾個關鍵字使用方法,對此感興趣的朋友一起學習吧
    2015-12-12
  • php模板引擎技術簡單實現(xiàn)

    php模板引擎技術簡單實現(xiàn)

    這篇文章主要為大家詳細介紹了php模板引擎技術簡單實現(xiàn),感興趣的小伙伴們可以參考一下
    2016-03-03
  • thinkphp框架page類與bootstrap分頁(美化)

    thinkphp框架page類與bootstrap分頁(美化)

    這篇文章主要介紹了thinkphp框架page類與bootstrap分頁(美化) ,需要的朋友可以參考下
    2017-06-06
  • ajax實現(xiàn)無刷新分頁(php)

    ajax實現(xiàn)無刷新分頁(php)

    直接給出源代碼,可自行分析,寫的不好請留言指正,謝謝!
    2010-07-07
  • PHP中針對區(qū)域語言標記信息的操作

    PHP中針對區(qū)域語言標記信息的操作

    大家都知道Locale 類就是操作區(qū)域語言相關內容的,它無法被實例化,所有全部功能方法都是靜態(tài)的。接下來通過本文給大家分享PHP中針對區(qū)域語言標記信息的操作,需要的朋友參考下吧
    2021-07-07
  • laravel7學習之無限級分類的最新實現(xiàn)方法

    laravel7學習之無限級分類的最新實現(xiàn)方法

    這篇文章主要給大家介紹了關于laravel7學習之無限級分類的最新實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • PHP中__set()實例用法和基礎講解

    PHP中__set()實例用法和基礎講解

    在本篇文章里小編給大家整理了關于HP中__set()實例用法和基礎講解,對此有需要的朋友們可以學習參考下。
    2019-07-07
  • yii2使用ajax返回json的實現(xiàn)方法

    yii2使用ajax返回json的實現(xiàn)方法

    這篇文章主要介紹了yii2使用ajax返回json的實現(xiàn)方法,實例分析了Yii框架使用ajax調用數(shù)據及返回json格式數(shù)據的相關技巧,需要的朋友可以參考下
    2016-05-05

最新評論