详细解析Laravel Model模型关联

广告:宝塔服务器面板,一键全能部署及管理,送你10850元礼包,点我领取~~~

详细解析Laravel Model模型关联

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

【相关推荐:laravel视频教程】

定义关联关系

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

一对一一对多多对多远程一对多远程一对一一对一(多态关联)一对多(多态关联)多对多建立模型关联

一对一

示例: 两个数据表:guest 用户表和guestinfo用户信息 其中guest表中的主键id字段对应着guestinfo中的外键user_id字段 首先创建两个model文件:php artisan make:model Guestphp 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('App\Models\Guestinfo','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('App\Models\Guest','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']); 访问路由: 结果为:

一对多

示例: 两个数据表: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('App\Models\April\Guest','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('App\Models\Guestinfo','user_id','id');    }    // 设置与article的关联:hasmany 有很多     public function article(){        return $this->hasMany('App\Models\April\Article','user_id','id');    }}
登录后复制

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

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

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

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

实例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('App\Models\April\Article','article_id','id');    }}
登录后复制

在Article模型中添加方法comment:

public function comment(){        return $this->hasMany('App\Models\April\Comment','article_id','id');    }
登录后复制

controller控制器代码:

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('App\Models\Guest','user_id','id');    }}0
登录后复制

【相关推荐:laravel视频教程】

以上就是详细解析Laravel Model模型关联的详细内容,更多请关注9543建站博客其它相关文章!

9543建站博客
一个专注于网站开发、微信开发的技术类纯净博客。
作者头像
admin创始人

肥猫,知名SEO博客站长,14年SEO经验。

上一篇:学习PHP7的革新与性能优化
下一篇:如何在PHP表单中集成验证码验证功能

发表评论

关闭广告
关闭广告