本文實例講述了Laravel框架查詢構造器常見用法。分享給大家供大家參考,具體如下:
查詢構造器也是我們使用laravel框架的一項必備技能,上一篇文章我們講到了如何使用原生增刪改查,這一篇我們就來講查詢構造器的增刪改查(以下知識點若有不全面的地方,還請多多諒解)
查詢構造器簡介:
Laravel查詢構造器提供方便流暢的接口,用來建立及執(zhí)行數據庫查找語法
使用PDO參數綁定,以保護應用程序免于SQL注入因此傳入的參數不需要額外轉移特殊字符
基本可以滿足所有數據庫操作,而且在所有支持的數據庫系統(tǒng)上都可以執(zhí)行
NO.1查詢構造器新增數據
1.最基本的新增
代碼如下:
namespace App\Http\Controllers;
use Illuminate\Support\Facades\DB;
class SController extends Controller
{
public function qur1()
{
$bool = DB::table('student')//table指的是一個數據表,而括號里的('student')則指的是一個名為student的數據表
->insert(
['name' => 'Rarin','age' =>16]
);
echo "pre>";
print_r($bool);
echo "/pre>";
}
}
ok,然后他會返回一個數字“1”,返回數字“1”則證明他已經新建了一條數據。
2.獲取一個新增的數據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,所以他會顯示一個數字“2”。
3.新增多條數據
代碼如下:
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查詢構造器修改數據
1.修改一條數據
代碼如下:
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>";
}
}
那么,他會輸出一個數字1,代表的是影響的行數是一行。
2.自增某條數據
代碼如下:
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,因為我一共有四行數據,所以他影響到了四行數據,自增了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,證明影響了四個行數,然后去查看的時候,可以發(fā)現每個數據的年齡都大了2歲
3.自減某條數據
自減的默認值和設置值的操作步驟與自增一致,唯一不同的就是關鍵字從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>";
}
}
然后他會返回一個受影響行數的值,我這里有四個行數受到了影響,所以返回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>";
}
}
因為受影響的數據只有id是為1的數據,所以他會返回數字1,證明受影響的行數只有一行,自減同理,不過多介紹
自減的時候修改其他字段(自增同理)
代碼如下:
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>";
}
}
他會返回一個受影響的行數值
NO.3查詢構造器刪除數據
1.刪除某條數據
代碼如下:
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>";
}
}
他會返回一個數字1,表示刪除的數據共有1行。
2.根據某個值刪除多條數據
代碼如下:
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>";
}
}
他會輸出相對應被刪除幾條數據的數字,我這里刪除了2條數據,所以他返回一個2
NO.4查詢構造器查詢數據
1.get方式獲取所有的數據
代碼如下:
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方式
獲取第一條數據
代碼如下:
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);
}
}
結果如下:
數據表如下:
3.where方式
插入一條數據
代碼如下:
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);
}
}
結果如下:
插入多條數據
代碼如下:
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方式
他只返回某個值,以數組的形式
代碼如下:
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方式
這個一般是用在數據過多的時候,為了流暢,設定每次輸出多少條數據
代碼如下:
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í)行,所以我們往匿名函數里增加一個if判斷語句來判斷再return即可
NO.5查詢構造器聚合函數
1.count函數
代碼如下:
namespace App\Http\Controllers;
use Illuminate\Support\Facades\DB;
class SController extends Controller
{
public function qur5()
{
$num = DB::table('student')
->count();
print_r($num);
}
}
他這個函數是輸出數據有幾條記錄,我這里數據有2條記錄,所以他會輸出一個2
2.max函數
代碼如下:
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);
}
}
返回數據里某個數據的最大值
3.min函數
代碼如下:
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函數
代碼如下:
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函數
代碼如下:
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);
}
}
返回數據里某個數據的總和
更多關于Laravel相關內容感興趣的讀者可查看本站專題:《Laravel框架入門與進階教程》、《php優(yōu)秀開發(fā)框架總結》、《php面向對象程序設計入門教程》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》
希望本文所述對大家基于Laravel框架的PHP程序設計有所幫助。
您可能感興趣的文章:- laravel技巧之查詢構造器Query Builder疊加鏈式調用的方法
- 使用Laravel中的查詢構造器實現增刪改查功能
- 解決laravel查詢構造器中的別名問題
- Laravel框架查詢構造器簡單示例
- Laravel框架查詢構造器 CURD操作示例
- Laravel 使用查詢構造器配合原生sql語句查詢的例子
- Laravel5中實現模糊匹配加多條件查詢功能的方法
- 在Laravel5.6中使用Swoole的協(xié)程數據庫查詢
- laravel實現查詢最后執(zhí)行的一條sql語句的方法
- Laravel Eloquent ORM 實現查詢表中指定的字段