Laravel(三)

数据库操作

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

新建数据表与连接数据库

新建一张学生表

Laravel(三)_第1张图片

数据库配置文件在config/database.php

        'mysql' => [
            'driver' => 'mysql',
            'host' => env('DB_HOST', 'localhost'),
            'port' => env('DB_PORT', '3306'),
            '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,
        ],

发现主机、端口、用户、密码对应的都是env,那么我们找到项目根目录下的env文件修改对应的参数;

使用DB facade实现CURD

首先新建一个StudentController.php控制器

使用路由访问,记得在routes.php文件中加上对应的路由地址;

Route::get('test', ['uses' => 'StudentController@test']);
  • Create(增)
public function test () {
    DB::insert('insert into student(name,age) values("gsy","18")');
    //另一种写法
    DB::insert('insert into student(name,age) values(?,?)', ['hh',20]);
}
  • Read(查)
public function test () {
    $result = DB::select('select * from student');
    dd($result);
}
  • Update(改)
DB::update('update student set age = ? where name = ?',[28,'gsy']);
  • Delete(删)
DB::delete('delete from student where id = ?',[2]);

查询构造器简介

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

使用查询构造器新增数据:

新增一个add方法

    public function add() {
        //添加一条数据,返回bool值
        $bool = DB::table('student')->insert(
            ['name' => 'wyx','age' => 18]
        );
        //添加多条数据,返回bool值
        $bool = DB::table('student')->insert([
            ['name' => 'hhh','age' => 19],
            ['name' => 'www','age' => 21],
        ]);
        //添加一条数据,返回主键ID
        $id = DB::table('student')->insertGetId(
            ['name' => 'wyx','age' => 18]
        );
    }

在routes.php文件中配置路由

Route::get('add',['uses' => 'StudentController@add']);

使用查询构造器修改数据:

新增一个update方法

    public function update() {
        //更新语句,返回影响行数
        $num = DB::table('student')->where('id',8)->update(['age' => 30]);
        //所有age字段值自增1,返回影响行数
        $num = DB::table('student')->increment('age');
        //指定字段自增3,返回影响行数
        $num = DB::table('student')->where('id',8)->increment('age',3);
        //所有age字段值自减1,返回影响行数
        $num = DB::table('student')->decrement('age');
        //指定字段自减3,返回影响行数
        $num = DB::table('student')->where('id',8)->decrement('age',3);
        //指定字段自减3同时修改name字段值为tom,返回影响行数
        $num = DB::table('student')->where('id',8)->decrement('age',3,['name' => 'tom']);
    }

在routes.php文件中配置路由

Route::any('update',['uses' => 'StudentController@update']);

使用查询构造器删除数据:

新增一个delete方法

    public function delete() {
        //删除ID为8的数据,返回影响行数
        $num = DB::table('student')->where('id',8)->delete();
        //删除ID>=6的数据,返回影响行数
        $num = DB::table('student')->where('id','>=',6)->delete();
    }

在routes.php文件中配置路由

Route::any('delete',['uses' => 'StudentController@delete']);

使用查询构造器查询数据:

新增一个select方法

    public function select() {
        //get方法获取表中所有数据
        $result = DB::table('student')->get();
        //first方法获取结果集第一条数据
        $result = DB::table('student')->first();
        //id降序后获取结果集第一条数据
        $result = DB::table('student')->orderBy('id','desc')->first();
        //where条件
        $result = DB::table('student')->where('id','>=',2)->get();
        //多个where条件
        $result = DB::table('student')->whereRaw('id >= ? and age > ?',[2,23])->get();
        //返回指定某个字段的一维数组
        $result = DB::table('student')->pluck('name');
        //返回指定字段的数组,并以age字段作为数组的下标,会去重
        $result = DB::table('student')->lists('name','age');
        //返回指定字段的多维数组
        $result = DB::table('student')->select('name','id','age')->get();
        //当数据库有几十万条数据的时候,如果使用get方法,服务器内存会爆
        //使用chunk分段获取数据,每个数组装2条数据,后面要跟上一个闭包也就是匿名函数
        DB::table('student')->chunk(2,function ($data) {
            dump($data);
        });
    }

在routes.php文件中配置路由

Route::any('select',['uses' => 'StudentController@select']);

查询构造器中的聚合函数

新建一个query方法

    public function query() {
        //count函数返回数据表记录总条数
        $num = DB::table('student')->count();
        //max函数返回该字段最大值
        $max = DB::table('student')->max('age');
        //min函数返回该字段最小值
        $min = DB::table('student')->min('age');
        //avg函数返回该字段平均值
        $avg = DB::table('student')->avg('age');
        //sum函数返回该字段总和
        $sum = DB::table('student')->sum('age');
    }

数据库操作之Eloquent ORM

Laravel自带的Eloquent ORM是一个优美、简介的ActiveRecord实现,用来实现数据库操作;
每个数据表都有一个与之相对应的“模型”用于和数据表交互;
模型的建立
app根目录下是模型的位置,新建Student.php模型文件与studen表对应

控制层新增ormRead查询方法

    public function ormRead() {
        //返回一个集合,attributes里面存放数据
        $result = Student::all();
        //返回一个集合,查出ID为4的数据
        $result = Student::find(4);
        //查询构造器get()在orm中的使用,查出所有数据
        $result = Student::get();
        //查询构造器first()在orm中的使用,根据条件查出数据
        $result = Student::where('id','>','2')->orderBy('age','desc')->first();
        //查询构造器chunk()在orm中的使用,每次查出2条数据
        Student::chunk(2,function ($data) {
            dump($data);
        });
    }

聚合函数也可在orm中使用,自行测试,查询构造器一定要熟练运用;
rotues.php添加对应路由

Route::any('ormRead',['uses' => 'StudentController@ormRead']);

你可能感兴趣的:(Laravel(三))