详细解析Laravel Model模型关联

本篇文章给大家带来了关于laravel的相关知识,其中主要介绍了关于model模型关联的相关问题,包括了一对一、一对多、多对多等内容,下面一起来看一下,希望对大家有帮助。

详细解析Laravel Model模型关联

【相关推荐:laravel

定义关联关系

数据库表通常相互关联。
例如,一篇博客文章可能有许多评论,或者一个订单对应一个下单用户。Eloquent 让这些关联的管理和使用变得简单,并支持多种类型的关联:常见的为前三种,在此我们也只讲解前三种关联

  • 一对一
  • 一对多
  • 多对多
  • 远程一对多
  • 远程一对一
  • 一对一(多态关联)
  • 一对多(多态关联)
  • 多对多

建立模型关联

一对一

示例:
两个数据表:guest 用户表和guestinfo用户信息
其中guest表中的主键id字段对应着guestinfo中的外键user_id字段
首先创建两个model文件:
php artisan make:model Guest
php artisan make:model Guestinfo
Guest model文件:

class Guest extends Model{     use HasFactory;     // 设置Guest模型对应的数据表     protected $table = 'guest';     // 关闭create_time和update_time字段自动管理     public $timestamps = false;     // 设置与guestinfo的关联方法,方法名建议使用被关联表的名字     public function guestinfo(){     // hasOne(被关联的名命空间,关联外键,关联的主键)         return $this->hasOne('AppModelsGuestinfo','user_id','id');     }}

Guestinfo model文件:

class Guestinfo extends Model{     use HasFactory;     // 设置Guest模型对应的数据表     protected $table = 'guestinfo';     // 关闭create_time和update_time字段自动管理     public $timestamps = false;     // 设置与guestinfo的关联方法,方法名建议使用被关联表的名字     public function guest(){     // hasOne(被关联的名命空间,关联外键,关联的主键)         return $this->belongsTo('AppModelsGuest','user_id','id');     }}

创建一个控制器将两个model文件连接起来:
php artisan make:controller Controllers
内容:

class Controllers extends Controller{     //     public function getOne(){     // 通过关联方法获取guest表中username = admin记录在guestinfo对应的记录     // ->guestinfo 是Guest模型文件里面定义的guestinfo方法         $guestInfo = Guest::firstWhere('username','admin')->guestinfo; 	// 通过关联方法获取guestinfo中id=3 记录在guest表中的对应记录         $data = Guestinfo::find(3)->guest;                  dump($guestInfo);         // 将模型转换成数组         dump($data->toArray());     }}

创建控制器的路由:
Route::get(‘relative/getOne’,[Controllers::class,’getOne’]);
访问路由:
结果为:
详细解析Laravel Model模型关联

一对多

示例:
两个数据表:guest 用户表和article文章表
其中guest表中的主键id字段对应着guestinfo中的外键user_id字段
创建articlemodel文件:
php artisan make:model Article

class Article extends Model{     use HasFactory;     // 设置Guest模型对应的数据表     protected $table = 'article'; 	// 关闭create_time和update_time字段自动管理         public $timestamps = false;     public function guest(){     // 设置与guest的关联方法,与一对一的从表设置一样         return $this->belongsTo('AppModelsAprilGuest','user_id','id');     }}

在Guest model文件中添加一个article 方法

class Guest extends Model{     use HasFactory;     // 设置Guest模型对应的数据表     protected $table = 'guest';     // 关闭create_time和update_time字段自动管理     public $timestamps = false;     // 设置与guestinfo的关联方法,方法名建议使用被关联表的名字     public function guestinfo(){     // hasOne(被关联的名命空间,关联外键,关联的主键)         return $this->hasOne('AppModelsGuestinfo','user_id','id');     }     // 设置与article的关联:hasmany 有很多      public function article(){         return $this->hasMany('AppModelsAprilArticle','user_id','id');     }}

在Controllers 控制器文件中测试一下:
实例1:查询某一个用户发表的所有文章:

 		// 查询某个用户发表的所有文章         $article = Guest::find(1)->article;         // 返回为数据集,需要遍历         foreach ($article as $v){             dump($v->toArray());         }

详细解析Laravel Model模型关联

实例2:查询某个用户最新发表的一篇文章

		// 查询某个用户最新发表的一篇文章         // article()生成一个构造器,可以进行筛选         $article = Guest::find(1)->article()->orderby('created_at','desc')->first();         dump($article->toArray());

详细解析Laravel Model模型关联
实例3:通过关联查询某篇文章的发表人的姓名

		//  通过article和guest关联,再通过guest关联的guestinfo获取姓名         $name = Article::find(2)->guest->guestinfo;         dump($name->name);

实例4:通过关联查询某篇文章的评论信息
创建Comment评论模型:
php artisan make:model Comment
Comment 模型代码:

class Comment extends Model{     use HasFactory;     // 设置Comment模型对应的数据表     protected $table = 'comment';     // 关闭create_time和update_time字段自动管理     public $timestamps = false;     // 设置与article的关联方法,方法名建议使用被关联表的名字     public function article(){         return $this->belongsTo('AppModelsAprilArticle','article_id','id');     }}

在Article模型中添加方法comment:

public function comment(){         return $this->hasMany('AppModelsAprilComment','article_id','id');     }

controller控制器代码:

$info = Article::find(2)->comment;         foreach ($info as $v){             dump($v->toArray());         }

详细解析Laravel Model模型关联

【相关推荐:laravel

© 版权声明
THE END
喜欢就支持一下吧
点赞11 分享