thinkphp6入门(13)-- 一对多关联模型

定义一对一关联,例如,一个用户都有多个工作经历。

一、两表

1.用户表:user

2.工作经验表:work_experience

user表的id关联work_experience表的user_id。

注意看,user_id=1的有2条工作经验

二、数据模型

主表模型:

复制代码
/**
 * 用户表
 */
class User extends Model{

    # 表名
    protected $table='user';
    /**
     * 查询用户的工作经验
     */
    public function userWorkExperience()
{
        //hasOne代表关联一张表  hasMany多张表  参数一:要关联的表 参数二:要关联表的外键 参数三:本表键
        return $this->hasMany(WorkExperience::class,'user_id','id');
    }
 
}

子表模型:

复制代码
/**
 * 工作经验
 */
class WorkExperience extends Model{
    # 表名
    protected $table='work_experience';
}

三、控制器

  1. 查询所有

    data = User::with('userWorkExperience')->select();dd(data->toArray());

关联数据会在一个"关联名"的字段里

没有关联的数据就是空数组\[\]

2.给User加查询条件

复制代码
$data = User::with('userWorkExperience')->where('id', '<=', 2)->select();
dd($data->toArray());​​​​​​​

只显示id小于等于2的记录

  1. 给关联模型增加条件

    data = User::with(['userWorkExperience' => function(query) { query->where('company', 'like', '美团%') ->field('id,user_id, company'); }])->where('id', '<', 3)->select(); dd(data->toArray());

同学们应该发现,一对多和一对一只是hasMany和hasOne的区别

另外还有挺多高级的用法,比如关联多张表、删除关联、更新关联,可自行探索

参考:

https://www.kancloud.cn/manual/thinkphp6_0/1037601

by 软件工程小施同学

相关推荐
安妮的小熊呢2 天前
CRMEB BZ v6.0 使用教程:从安装部署到后台基础配置
php·thinkphp·电商系统·crmeb
withoutfear10 天前
Fastadmin中获取IP和手机号归属地信息
php·thinkphp·fastadmin·ip归属地·手机号归属地
qq31869299615 天前
ThinkPHP + Supervisor 队列任务丢失:僵尸 Worker 排查全记录
服务器·thinkphp·宝塔
linlinlove215 天前
前端uniapp、后端thinkphp股票系统开发功能展示、代码披露、HQChart
前端·uni-app·echarts·thinkphp·hqchart·配资·deepseek选股票
SuperherRo1 个月前
服务攻防-开发框架安全&ThinkPHP&Laravel&SpringBoot&Struts2&SpringCloud&复现
spring boot·laravel·thinkphp·struts2·框架安全
quweiie1 个月前
thinkphp8生成海报
thinkphp·海报
云游云记2 个月前
FastAdmin 路由完全开启教程:去掉 index 前缀 + 优雅路由配置
thinkphp
kertag2 个月前
ThinkPHP 8 多应用入口绑定:BIND_MODULE vs $http->name() 全面解析
php·thinkphp
妙码生花3 个月前
全新的 TP8+Workerman+BuildAdmin 整合方案,已有近 2000 次下载使用。
websocket·php·thinkphp
quweiie3 个月前
在php8.3下签到、签退打卡的实现
thinkphp·签到·nesbot/carbon