Laravel之Eloquent ORM

一、ORM编程思想

1.1 Active Record 设计模式

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

1.2 调试工具 Laravel Debugbar

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),
    ];
});

获取每个国家论文总数:

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

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

伪造数据:

六、多对多多态关联

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

原文地址:https://www.cnblogs.com/liliuguang/p/9945657.html

时间: 2024-10-13 06:46:58

Laravel之Eloquent ORM的相关文章

Laravel使用Eloquent ORM操作数据库

1.定义模型 <?php namespace App; use Illuminate\Database\Eloquent\Model; class Flight extends Model{ protected $table = 'my_flights'; protected $primaryKey = 'my_id'; public $timestamps = false; } 2.获取表中所有数据all/get $flights = Flight::all();$flights = App\

Lavavel笔记 Eloquent ORM分页源码分析

安装了laravel-debugbar后打开一个列表页面,发现页面输出有两个 select count(*) 语句,这是一个严重的设计缺陷呀. 查看代码 $users = User::where('votes', '>', 100)->paginate(15); $count = User::where('votes', '>', 100)->count(); 之前就感觉paginate分页应该是使用了count,但是不知道怎么取总量数据所以又写了一个count(). var_du

Eloquent ORM学习笔记

最近在学习Laravel,觉得ORM功能很强大,我这里只是简单探索了一点,如果有更好的笔记,还请分享. 因为重点在于Eloquent ORM,所以路由设置,控制器就不详细描述了,这里直接进入Models么模块. 1.数据库准备(Mysql) 在这里需要创建users和users_ext两张表,并初始化数据: 1 CREATE TABLE 2 IF NOT EXISTS users ( 3 iAutoId INT (11) NOT NULL AUTO_INCREMENT, 4 sNmame VAR

laravel框架之ORM模型

ORM模型简介 1>什么是ORM? ORM,即 Object-Relational Mapping(对象关系映射),它的作用是在关系型数据库和业务实体对象之间作一个映射,这样,我们在操作具体的 业务对象时,就不需要再去和复杂的SQL语句打交道,只需简单的操作对象的属性和方法即可. 2>ORM 两种最常见的实现方式是 ActiveRecord 和 DataMapper, ActiveRecord(非常流行) 中模型与数据表一一对应, DataMapper 中模型与数据表是完全分离的. 3>

DB门面,查询构建器,Eloquent ORM三者的CURD

一.DB门面 1.insert DB::insert('insert into table(`name`) value(?)', ['test']); 2.update DB::update('update into table set name=? where id=?', ['test', 10]); 3.delete DB::delete('delete from tb where id=?', [1]); 4.select DB:select('select * from tb'); 二

Eloquent ORM 之关联查询

小伙伴们好,本文是在我的前一篇随笔的基础上完成的,还没有浏览的同学,请移尊驾哦 Eloquent ORM学习笔记. 前一篇文章用到了leftJoin方法,其实Eloquent对于模块之间的关联查询有自己封装,接下来我们就一起研究Eloquent的关联是如何应用的. 1.创建Models 前一篇文章创建了UserModel,其实对于users_ext也可以创建一个Model:  UserExtModel.php <?php class UserExtModel extends \Eloquent

Laravel Eloquent ORM 数据model操作

Laravel ORM 数据model操作 注意:ORM关联操作最后一定要记得带get()方法!否则会获取不到数据,为null 如: posts表 comments表  id id  contents post_id comment post模型内定义一对多关系hasMany 1 //定义关联关系 2 public function comments(){ 3 return $this->hasMany(Comments::class,'post_id','id'); 4 } 1 //容器内调用

Laravel 数据库操作之Eloquent ORM模型

//模型中的相关代码 namespace App; use Illuminate\Database\Eloquent\Model; class Student extends Model{ //默认对应的是模型复数,即students,如果不是,需要自己指定表名 protected $table = 'student';//指定表名 //默认主键是id,如果不是,需要指定 protected $primaryKey = 'id'; //自动维护时间戳 public $timestamps = t

Laravel Eloquent ORM 一种高级用法

一.需求: <span style="white-space:pre"> </span>在数据搜索时最常见的就是调用同一个方法查询,而查询的字段却可能是其中一个或其中的几个字段一起组合查询,例如:对列表的搜索,基本上都是几个字段随意组合搜索.那么在model里就需要判断有那个字段组合,怎么组合. 网上找了很久,Laravel群里也问了几个,都说没有写过,于是自己写个吧.话不多说,见代码: function findByParam($param = array()