Laravel(三)

数据库操作

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

推荐阅读更多精彩内容