美文网首页
Laravel(三)

Laravel(三)

作者: PHPer_ | 来源:发表于2017-09-06 10:41 被阅读82次

    数据库操作

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

    新建数据表与连接数据库

    新建一张学生表

    数据库配置文件在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控制器

    <?php
    namespace App\Http\Controllers;
    use Illuminate\Support\Facades\DB;
    class StudentController extends Controller {
        public function test () {
            return 'test';
        }
    }
    

    使用路由访问,记得在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表对应

    <?php
    namespace App;
    use Illuminate\Database\Eloquent\Model;
    
    class Student extends Model {
        //关联表名
        protected $table = 'student';
        //指定主键
        protected $primaryKey = 'id';
    }
    

    控制层新增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(三)

          本文链接:https://www.haomeiwen.com/subject/yiymjxtx.html