數(shù)據(jù)庫增刪改查CURD操作
// 添加數(shù)據(jù) 返回bool值
// $bool = DB::insert('insert into student(name,age) values(?,?)',['imooc',19]);
// var_dump($bool);
// 更新數(shù)據(jù)
// $num = DB::update('update student set age = ? where name = ?',[20,'sean']);
// var_dump($num);
// 查詢數(shù)據(jù)
// $students = DB::select('select * from student where id > ?',[1001]);
// dd($students);
// 刪除數(shù)據(jù)
$num = DB::delete('delete from student where id > ?',[1001]);
var_dump($num);
數(shù)據(jù)庫操作之-查詢構(gòu)造器
- 查詢構(gòu)造器簡介及新增數(shù)據(jù)
- 使用查詢構(gòu)造器修改數(shù)據(jù)
- 使用查詢構(gòu)造器刪除數(shù)據(jù)
- 使用查詢構(gòu)造器查詢數(shù)據(jù)
- 查詢構(gòu)造器中的聚合函數(shù)
1. 查詢構(gòu)造器簡介
- laravel查詢構(gòu)造器(query builder)提供方便陈醒、流暢的接口同仆,用來建立執(zhí)行數(shù)據(jù)庫查找語法
- 使用PDO參數(shù)綁定甥郑,以保護應(yīng)用程序免于SQL注入因此傳入的參數(shù)不需額外轉(zhuǎn)義特殊字符
- 基本上可以滿足所有的數(shù)據(jù)庫操作,而且在所有支持的數(shù)據(jù)庫系統(tǒng)上都可以執(zhí)行
1. 使用查詢構(gòu)造器新增數(shù)據(jù)
// 插入數(shù)據(jù) 返回插入數(shù)據(jù)的bool值
// $bool = DB::table('student')->insert(
// ['name'=>'imooc','age'=>18]
// );
// var_dump($bool);
// 插入數(shù)據(jù) 返回插入數(shù)據(jù)的id
// $id = DB::table('student')->insertGetId(
// ['name'=>'sean','age'=>18]
// );
// var_dump($id);
// 插入多條數(shù)據(jù)
$bool = DB::table('student')->insert(
[
['name'=>'name1','age'=>20],
['name'=>'name2','age'=>21],
]
);
var_dump($bool);
2. 使用查詢構(gòu)造器更新數(shù)據(jù)
// 更新數(shù)據(jù)倡缠,返回受影響行數(shù)
// $num = DB::table('student')
// ->where('id',1003)
// ->update(['age'=>30]);
// var_dump($num);
// 自增 默認自增1 將所有的age自增1
// $num = DB::table('student')->increment('age');
// 自增 將所有的age自增3
// $num = DB::table('student')->increment('age',3);
// 自減 將所有的age自減3
// $num = DB::table('student')->decrement('age',3);
// 自減 默認自減1 將所有的age自減1
// $num = DB::table('student')->decrement('age');
// 將id為1003的age自減3
// $num = DB::table('student')
// ->where('id',1003)
// ->decrement('age',3);
// 自減的同時,修改其他字段
$num = DB::table('student')
->where('id',1003)
->decrement('age',3,['name'=>'iimooc']);
var_dump($num);
3. 使用查詢構(gòu)造器刪除數(shù)據(jù)
// $num = DB::table('student')
// ->where('id',1006)
// ->delete();
// $num = DB::table('student')
// ->where('id','>=',1003)
// ->delete();
// var_dump($num);
// 不返回任何東西 刪除所有數(shù)據(jù)
DB::table('student')->truncate();
4. 使用查詢構(gòu)造器查詢數(shù)據(jù)
- get()
- first()
- where()
- pluck()
- lists()
- select()
- chunk()
// 插入數(shù)據(jù) 返回插入數(shù)據(jù)的bool值
// $bool = DB::table('student')->insert([
// ['id'=>1001,'name'=>'name1','age'=>18],
// ['id'=>1002,'name'=>'name2','age'=>18],
// ['id'=>1003,'name'=>'name3','age'=>19],
// ['id'=>1004,'name'=>'name4','age'=>20],
// ['id'=>1005,'name'=>'name5','age'=>21]
// ]);
// var_dump($bool);
// get() 獲取表的所有數(shù)據(jù)
// $students = DB::table('student')->get();
// first() 獲取結(jié)果集中的第一條數(shù)據(jù)
// $student = DB::table('student')
// ->orderBy('id','desc')
// ->first();
// where
// $students = DB::table('student')
// ->where('id','>=',1002)
// ->get();
// 多個條件
// $students = DB::table('student')
// ->whereRaw('id >= ? and age > ?',[1001,18])
// ->get();
// pluck 返回結(jié)果集中的字段
// $names = DB::table('student')
// ->pluck('name');
// lists 返回結(jié)果集中的字段 指定某個字段做下標
// $names = DB::table('student')
// ->lists('name','id');
// select
// $selects = DB::table('student')
// ->select('id','name','age')
// ->get();
// dd($selects);
// chunk
echo '<pre>';
DB::table('student')->chunk(2,function($students){
var_dump($students);
if (true) {
return false;
}
});
5. 使用查詢構(gòu)造器中的聚合函數(shù)
- count()
- max()
- min()
- avg()
- sum()
// $num = DB::table('student')->count();
// $max = DB::table('student')->max('age');
// $min = DB::table('student')->min('age');
// $avg = DB::table('student')->avg('age');
$sum = DB::table('student')->sum('age');
var_dump($sum);