laravel学习笔记(3)— 数据库操作之

来源:互联网 发布:淘宝店铺异常无法开店 编辑:程序博客网 时间:2024/06/04 01:26

Laravel 中提供了DB facade(原始查找)查询构造器Eloquent ORM三种操作数据库方式

一、数据库操作之—DB facade:

新建数据表与连接数据库:

新建数据表:

CREATE TABLE IF NOT EXISTS student(  `id` INT AUTO_INCREMENT PRIMARY KEY,  `name` VARCHAR(255) NOT NULL DEFAULT '' COMMENT '姓名',  `age` TINYINT UNSIGNED NOT NULL DEFAULT 0 COMMENT '年龄',  `sex` TINYINT UNSIGNED NOT NULL DEFAULT 10 COMMENT '性别',  `created_at` INT NOT NULL DEFAULT 0 COMMENT '新增时间',  `updated_at` INT NOT NULL DEFAULT 0 COMMENT '修改时间')ENGINE=INNODB DEFAULT CHARSET = UTF8 AUTO_INCREMENT=1001 COMMENT='学生表';
连接数据库:

1.找到数据库的配置 config/database.php

'default' => env('DB_CONNECTION', 'mysql'), //查看默认数据库是否正确

//看mysql的具体配置是否正确        'mysql' => [            'driver'    => 'mysql',            'host'      => env('DB_HOST', 'localhost'),            'database'  => env('DB_DATABASE', 'forge'),            'username'  => env('DB_USERNAME', 'forge'),            'password'  => env('DB_PASSWORD', ''),            'charset'   => 'utf8',            'collation' => 'utf8_unicode_ci',            'prefix'    => '',            'strict'    => false,            'engine'    => null,        ],
2.找env文件

修改配置DB_HOST=localhostDB_DATABASE=testDB_USERNAME=rootDB_PASSWORD=root

使用DB facade实现CURD

StudentController中<?phpnamespace App\Http\Controllers;use Illuminate\Support\Facades\DB;class StudentController extends Controller{public function test1(){//插入/*$bool = DB::insert('insert into student(name,age) value(?,?)',['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');dd($students);*///删除$num = DB::delete('delete from student where id > ?',['1002']); //返回成功的行数var_dump($num);}}?>


二、数据库操作之—查询构造器

1.查询构造器简介及新增数据

● laravel查询构造器(query builder)提供方便、流畅的接口,用来建立及执行数据库查找语法。

● 使用PDO参数绑定,以保护应用程序免于SQL注入因此传入的参数不需额外转义特殊字符。

● 基本可以满足所有的数据库操作,而且在所有支持的数据库系统上都可以执行。

使用查询构造器新增:

 //使用查询构造器插入数据        DB::table('student')->insert(array('name' => jason,'age' => 18)); //返回布尔类型        DB::table('student')->insertGetId(array('name' => jason,'age' => 18)); //返回插入的id        DB::table('student')->insert([['name' => 'jason','age' => 18],['name' => 'jason2','age' => 18]]); //插入多条数据,返回布尔类型
2.使用查询构造器修改数据

更新为指定的内容

 //使用查询构造器更新数据        DB::table('student')->where('id', 12)->update(['age' => 18]); //返回影响的行数
自增和自减

DB::table('as_admin')->where('id', 12)->increment('age', 3); //字段自增3写,默认为1法 返回影响的行数        DB::table('as_admin')->where('id', 12)->decrement('age', 3); //字段自减3写,默认为1法 返回影响的行数        DB::table('as_admin')->where('id', 12)->increment('age', 3, ['name' => '张佳宁']); //自增或自减的同时更新name字段

3.使用查询构造器删除数据

● delete

● truncate

//使用查询构造器删除数据public function query3(){/*$num = DB::table('student')->where('id',11)->delete();*/$num = DB::table('student')->where('id', '>=', 9)->delete();var_dump($num);//返回删除的行数DB::table('student')->truncate();//整表删除,这个操作很危险,谨慎使用,不返回任何数;}

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

● get()          ● lists()

● first()         ● select()

● where()     ● chunk()

● pluck()

//get() 获取表中所有数据//$students = DB::table('student')->get();//first() 获取第一条数据随机,常配合orderBy 一起使用//$students =  DB::table('student')->orderBy('id','asc')->first();//where 多条件查询/*$students = DB::table('student')->whereRaw('id >= ? and age > ?',[18,20])->get();*///pluck 取结果集中一列特定列,返回字符串类型/*$students = DB::table('student')->pluck('id','name','age');*///lists 按照Key=>value 对 的方式返回数组;最多两个参数,第一个参数作为value,第二个做为key。一个参数时与pluck用法一样/*$students = DB::table('student')->whereRaw('id >= ? and age > ?',[18,20])->lists('id','name','age');*///select() 指定查询的字段/*$students = DB::table('student')->select('id','name','age')->get();*///chunk() 方法 指定一次返回多少条,后跟闭包(匿名函数)/*echo '<pre>';//预格式化DB::table('student')->chunk(2,function($students){var_dump($students);if(你的条件){     return false;}});*/dd($students);
5.查询构造器中的聚合函数

● count()            ● avg()

● max()              ● min()

● sum

  //聚合函数        DB::table('student')->count(); //返回记录数        DB::table('student')->max('age'); //最大值,min同理        DB::table('student')->avg('age'); //返回平均值        DB::table('student')->sum('sum'); //求某一列和


0 0
原创粉丝点击