Laravel中Model模型关联关系有哪些,怎么建立关系
Admin 2022-06-15 群英技术资讯 1185 次浏览
这篇文章将为大家详细讲解有关“Laravel中Model模型关联关系有哪些,怎么建立关系”的知识,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
数据库表通常相互关联。
例如,一篇博客文章可能有许多评论,或者一个订单对应一个下单用户。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控制器代码:
$info = Article::find(2)->comment;
foreach ($info as $v){
dump($v->toArray());
}
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
下面由workerman教程栏目给大家介绍使用workerman进行消息推送的方法,希望对需要的朋友有所帮助!Workerman是一款纯PHP开发的开源高性能的PHP socket 服务器框架。被广泛的用于手机app、移动通讯,微信小程序。
引用传递可以将一个变量通过引用传递给函数,这样该函数就可以修改其参数的值。语法如下:<?phpfunctionfoo(&$var){$var++;}$a=5;fo...
php中Phalcon框架需要学习以下内容:1、引入文件;2、安装命令行工具;3、运行命令;4、构造项目;5、生成控制器;
环境部署一直是一个很大的问题,无论是开发环境还是生产环境,但是Docker将开发环境和生产环境以轻量级方式打包,提供了一致的环境,下面这篇文章主要给大家介绍了关于利用Dockerfile文件部署php项目的相关资料,需要的朋友可以参考下
本篇文章给大家介绍一下PHP7引入的“??” 和“?:”区别。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008