专栏首页唐成勇Laravel之Eloquent ORM

Laravel之Eloquent ORM

一、ORM编程思想

1.1 Active Record 设计模式

Active Record 是一种数据访问设计模式,它可以帮助你实现数据对象Object到关系数据库的映射。应用Active Record时,每一个类的实例对象唯一对应一个数据库表的一行(一对一关系)。你只需继承一个abstract Active Record 类就可以使用该设计模式访问数据库,其最大的好处是使用非常简单

1.2 调试工具 Laravel Debugbar

https://github.com/barryvdh/l...

Installation:

composer require barryvdh/laravel-debugbar --dev

二、一对一关系映射

2.1 创建表

public function up()
    {
        Schema::create('profiles', function (Blueprint $table) {
            $table->increments('id');
            $table->string('phone');
            $table->unsignedInteger('user_id');
            //显示的声明外键:通知数据库根据外键关联表和建立索引,提高运行速度
            $table->foreign('user_id')
                ->references('id')
                ->on('users')
                ->onDelete('cascade');

            $table->timestamps();
        });
    }

2.2 创建模型关系

2.2.1 正向关系绑定

public function profile()
{
    return $this->hasOne(Profile::class);
}

2.2.2 反向关系绑定

public function user()
{
    return $this->belongsTo(User::class);
}

2.3 外键

自定义外键:

return $this->hasOne(Profile::class,'显示指定自定义外键');

2.4 一对一测试

依赖注入Request $request,获取当前登录用户$request->user()

Route::get('/test',function (Request $request){
    //反向
//    $profile = \App\Profile::find(1);
//    dd($profile->user);
    $user = $request->user();

//    if (is_null($user->profile)){
//        $user->profile()->create([
//            'phone' => '15801340269'
//        ]);
//    }
    //用firstOrCreate改进if
    $user->profile()->firstOrCreate(['user_id' => $user->id],[

        'phone' => '18363046291'
    ]);

    //访问属性一样访问方法
    dd($user->profile);
});

三、一对多关系映射

1:N hasMany(XXX:class) 

反之:belongsTo(XXX:class)

3.1 面向对象方式绑定一对多的关系

四、多对多关系映射

中间表命名:按照A-Z首字母排序

public function users()
{
    return $this->belongsToMany(User::class);
}

public function habits()
{
    return $this->belongsToMany(Habit::class);
}

4.1 面向对象方式绑定多对多的关系

detach解绑,sync方法用的比较多,只保留1,2

4.2 访问多对多中间数据表

五、HasManyThrough对象桥接式穿越关联(远层一对多)

数据表:

countries
    id - integer
    name - string

users
    id - integer
    country_id - integer
    name - string

posts
    id - integer
    user_id - integer
    title - string
class Country extends Model
{
    protected $fillable = ['name'];

    /**
     * 获得某个国家下所有的用户文章。
     */
    public function papers()
    {
        return $this->hasManyThrough(Paper::class,User::class);
    }
}
$factory->define(App\Paper::class, function (Faker $faker) {
    return [
        'title' => $faker->sentence,
        'user_id' => \App\User::all()->random()->id,
    ];
});
$factory->define(App\User::class, function (Faker $faker) {
    return [
        'name' => $faker->name,
        'email' => $faker->unique()->safeEmail,
        'country_id' => \App\Country::all()->random()->id,
        'password' => '$2y$10$TKh8H1.PfQx37YgCzwiKb.KjNyWgaHb9cbcoQgdIVFlYg7B77UdFm', // secret
        'remember_token' => str_random(10),
    ];
});

获取每个国家论文总数:

五、多样化的一对多关系映射(多态关联)

面向对象多态:运行时加载机制

更多:https://laravel-china.org/doc... 伪造数据:

六、多对多多态关联

除了传统的多态关联,您也可以定义「多对多」的多态关联。例如,Post 模型和 Video 模型可以共享一个多态关联至 Tag 模型。 使用多对多多态关联可以让您在文章和视频中共享唯一的标签列表。 更多:https://laravel-china.org/doc...

参考教程:Coding 10编程原动力-Eloquent ORM Laravel 中文文档:Eloquent:关联

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Laravel之IOC Container的工作机制、理解Service Provider和中间件

    依赖注入:不需要通过new关键字去实例化对象,laravel用了PHP的一个机制:反射机制。一层一层向上找,然后自动实例化对象,而不需要自己去手动去ne...

    唐成勇
  • Laravel5.5之事件监听、任务调度、队列

    你写好任务类后,就能通过 dispatch 辅助函数来分发它了。唯一需要传递给 dispatch 的参数是这个任务类的实例: 利用模型工厂生成30个用户...

    唐成勇
  • Docker简介、常用命令与实践(二)

    Docker Hub 上有大量的高质量的镜像可以用,这里我们就说一下怎么获取这些镜像。 从 Docker 镜像仓库获取镜像的命令是 docker pull。其命...

    唐成勇
  • mssql 优化之索引部分

    具有较高的 index_advantage 的索引那些 SQL 服务器认为会产生最大的积极影响,减少工作量,基于查询的成本和预期他们会使用索引的次数减少。

    旺财的城堡
  • flask flask-login详解(flask 54)

    我们看到只要给路由函数加一个@login_required装饰器就可以了,那么这个装饰器究竟是怎么做到的呢?来看下源码:

    用户5760343
  • 如何获取JVM堆转储文件

    堆转储是诊断与内存相关的问题(例如内存泄漏缓慢,垃圾回收问题和 java.lang.OutOfMemoryError。它们也是优化内存消耗的重要工具。

    八音弦
  • 一场官司曝光了Waymo激光雷达技术细节

    陈桦 允中 编译整理 量子位 报道 | 公众号 QbitAI Waymo/谷歌无人车与Uber/Otto之间漫长的专利诉讼终于告一段落,上周五,Otto联合创始...

    量子位
  • 一个完整的Django入门指南(三)

    第五部分  Introduction Welcome to the 5th part of the tutorial series! In this tutor...

    zhang_derek
  • Go 语言递归函数

    递归,就是在运行的过程中调用自己。 语法格式如下: func recursion() { recursion() /* 函数调用自身 */ } func ...

    李海彬
  • 硬纪元AI峰会前瞻:智能制造如何高效利用好大数据?

    镁客网

扫码关注云+社区

领取腾讯云代金券

玩转腾讯云 有奖征文活动