文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Laravel Model模型关联怎么建立

2023-06-30 16:06

关注

这篇文章主要介绍“Laravel Model模型关联怎么建立”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Laravel Model模型关联怎么建立”文章能帮助大家解决问题。

定义关联关系

数据库表通常相互关联。
例如,一篇博客文章可能有许多评论,或者一个订单对应一个下单用户。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('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控制器代码:

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

关于“Laravel Model模型关联怎么建立”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯