Laravel数据库操作之-增删改查CURD操作

数据库增删改查CURD操作

// 添加数据  返回bool值
// $bool = DB::insert('insert into student(name,age) values(?,?)',['imooc',19]);
// var_dump($bool);

// 更新数据
// $num = DB::update('update student set age = ? where name = ?',[20,'sean']);
// var_dump($num);

// 查询数据
// $students = DB::select('select * from student where id > ?',[1001]);
// dd($students);

// 删除数据
$num = DB::delete('delete from student where id > ?',[1001]);
var_dump($num);

数据库操作之-查询构造器

  1. 查询构造器简介及新增数据
  2. 使用查询构造器修改数据
  3. 使用查询构造器删除数据
  4. 使用查询构造器查询数据
  5. 查询构造器中的聚合函数

1. 查询构造器简介

  • laravel查询构造器(query builder)提供方便、流畅的接口,用来建立执行数据库查找语法
  • 使用PDO参数绑定,以保护应用程序免于SQL注入因此传入的参数不需额外转义特殊字符
  • 基本上可以满足所有的数据库操作,而且在所有支持的数据库系统上都可以执行

1. 使用查询构造器新增数据

// 插入数据 返回插入数据的bool值
// $bool = DB::table('student')->insert(
//  ['name'=>'imooc','age'=>18]
//  );
// var_dump($bool);

// 插入数据 返回插入数据的id
// $id = DB::table('student')->insertGetId(
//  ['name'=>'sean','age'=>18]
//  );
// var_dump($id);

// 插入多条数据
$bool = DB::table('student')->insert(
        [
            ['name'=>'name1','age'=>20],
            ['name'=>'name2','age'=>21],
        ]
    );
var_dump($bool);

2. 使用查询构造器更新数据

  • 更新为指定的内容
  • 自增和自减
// 更新数据,返回受影响行数
// $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. 使用查询构造器删除数据

  • delete
  • truncate
// $num = DB::table('student')
//  ->where('id',1006)
//  ->delete();

// $num = DB::table('student')
//  ->where('id','>=',1003)
//  ->delete();
// var_dump($num);

// 不返回任何东西 删除所有数据
DB::table('student')->truncate();

4. 使用查询构造器查询数据

  • get()
  • first()
  • where()
  • pluck()
  • lists()
  • select()
  • chunk()
// 插入数据 返回插入数据的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() 获取表的所有数据
// $students = DB::table('student')->get();

// first() 获取结果集中的第一条数据
// $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 返回结果集中的字段
// $names = DB::table('student')
//  ->pluck('name');

// lists 返回结果集中的字段 指定某个字段做下标
// $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. 使用查询构造器中的聚合函数

  • 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);
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351

推荐阅读更多精彩内容