ThinkPHP 8的一对一关联

news/2025/1/16 11:38:22/

【图书介绍】《PHP.html" title=ThinkPHP>ThinkPHP 8高效构建Web应用》-CSDN博客

《2025新书 PHP.html" title=ThinkPHP>ThinkPHP 8高效构建Web应用 编程与应用开发丛书 夏磊 清华大学出版社教材书籍 9787302678236 PHP.html" title=ThinkPHP>ThinkPHP 8高效构建Web应用》【摘要 书评 试读】- 京东图书

使用VS Code开发PHP.html" title=ThinkPHP>ThinkPHP项目-CSDN博客

编程与应用开发_夏天又到了的博客-CSDN博客

关系数据库中的关联关系是其核心组成部分之一,它们可以确保数据的一致性、优化查询语句、实现复杂的业务逻辑等。通过定义关联关系,可以使得不同表之间存在明确的对应关系,从而更好地反映业务需求。

在工程实践中,一般有一对一、一对多、多对多三种关联关系。本文讲解PHP.html" title=ThinkPHP>ThinkPHP 8的一对一关联。

每个主模型有一个关联模型,可以选择在主模型添加外键或者在关联模型添加外键,在模型中使用hasOne方法定义。下面以用户模型和用户资料模型的示例来演示一对一关联,用户表参见8.1节,这里再创建一个用户资料表profile并加入一条id为1的记录(可以使用MySQL Workbench工具来操作表及其数据,学习起来相对方便),SQL语句如下:

CREATE TABLE `profile` (`id` int NOT NULL,`mobile` varchar(45) DEFAULT NULL,`email` varchar(45) DEFAULT NULL,PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3;
INSERT INTO `mydb`.`profile`(`id`,`mobile`,`email`) VALUES(1 ,'13701352990','tom@163.com' );
1. 用户模型

用户模型的示例如下:

<?php
namespace app\model;use think\Model;class UserModel extends Model
{protected $table = 'users';// 设置字段信息protected $schema = ['id'			=> 'int','name'		=> 'string','nickname'	=> 'string','status'		=> 'int',];public function profile(){return $this->hasOne(ProfileModel::class, 'id'); // hasOne}
}

PHP.html" title=ThinkPHP>ThinkPHP 8中默认会使用profile数据表的id作为关联键,可以在定义关联关系时指定。比如,上面代码中我们指定id为profile的关联键:

return $this->hasOne(ProfileModel::class, 'id');
2. 属性模型

属性模型的示例如下:

<?php
namespace app\model;use think\Model;class ProfileModel extends Model
{protected $table = 'profile';// 设置字段信息protected $schema = ['id'       => 'int','mobile'  => 'string','email'   => 'string',];
}
3. 关联查询

关联查询的示例如下:

<?php
namespace app\controller;use think\Model;
use app\model\UserModel;
use app\model\ProfileModel;class User {public function one2one(){$user = UserModel::find(1);// 输出用户资料中的电子邮箱return $user->profile->email;}
}

上面2个模型1个控制器完成后,运行服务器,在浏览器中访问http://localthost:8000/user/one2one,可以查询出id为1的用户的电子邮箱。

4. 根据关联数据查询

上面的示例中,我们是基于主模型进行查询的,那么也可以根据关联模型进行查询。

下面是查询昵称为admin开头的用户示例:

$users = User::hasWhere('profile', function(Query $query) {$query->where('email', 'like', 'tom%');
})->select();
5. 关联预载入

默认情况下,只有在访问关联模型的属性时,才会查询关联模型数据。比如下面的示例中,如果有10个$users,将产生11条查询(1条查询主模型列表,10条查询用户资料),这就是著名的数据库N+1问题。

$users = UserModel::select();
foreach ($users as $user) {echo $user->profile->email;
}

使用以下两种方案解决N+1问题:

(1)两次查询。第一次查询用户列表,取得用户ID列表,第二次使用IN查询方法查询用户资料。

(2)连表查询。直接使用数据库JOIN语句同时查询用户和用户资料。

PHP.html" title=ThinkPHP>ThinkPHP 8对上面两种方法都有对应的实现。

6. 两次查询

使用with方法传入关联名称即可,示例如下:

$users = UserModel::with('profile')->select();
foreach ($users as $user) {echo $user->profile->email;
}

如果需要自定义关联查询对象,则可以使用闭包,示例如下:

$users = UserModel::with(['profile'	=> function(Query $query) {$query->field(['id','name','email']);
}])->select();
foreach ($users as $user) {echo $user->profile->email;
}


http://www.ppmy.cn/news/1563586.html

相关文章

RPC 源码解析~Apache Dubbo

解析 RPC&#xff08;远程过程调用&#xff09;的源码可以帮助你深入理解其工作原理和实现细节。为了更好地进行源码解析&#xff0c;我们选择一个流行的 RPC 框架——Apache Dubbo 作为示例。Dubbo 是一个高性能、轻量级的开源 Java RPC 框架&#xff0c;广泛应用于企业级应用…

(即插即用模块-Attention部分) 四十四、(ICIP 2022) HWA 半小波注意力

文章目录 1、Half Wavelet Attention2、代码实现 paper&#xff1a;HALFWAVELET ATTENTION ON M-NET FOR LOW-LIGHT IMAGE ENHANCEMENT Code&#xff1a;https://github.com/FanChiMao/HWMNet 1、Half Wavelet Attention 传统的图像增强方法主要关注图像在空间域的特征信息&am…

【Linux】从零开始:编写你的第一个Linux进度条小程序

Linux相关知识点可以通过点击以下链接进行学习一起加油&#xff01;初识指令指令进阶权限管理yum包管理与vim编辑器GCC/G编译器make与Makefile自动化构建GDB调试器与Git版本控制工具 文章目录 一、知识铺垫1.1 回车与换行概念1.2 缓冲区 二、实现简单倒计时三、进度条3.1 Verrs…

十五、从0开始卷出一个新项目之瑞萨RZN2L之PHID例程

一、概述 RZN2L未提供PHID的例程&#xff0c;这里提供来逻辑PHID和RTOS PHID例程 USB知识&#xff1a;嵌入式科普(24)一张图真正看懂USB通信协议 二、README.txt 1.接电源线、调试线、串口线、usb线到pc 2、xspi模式运行&#xff0c;启动后串口输出日志&#xff0c;HID收发…

Python----Python高级(函数基础,形参和实参,参数传递,全局变量和局部变量,匿名函数,递归函数,eval()函数,LEGB规则)

一、函数基础 1.1、函数的用法和底层分析 函数是可重用的程序代码块。 函数的作用&#xff0c;不仅可以实现代码的复用&#xff0c;更能实现代码的一致性。一致性指的是&#xff0c;只要修改函数的代码&#xff0c;则所有调用该函数的地方都能得到体现。 在编写函数时&#xf…

了解npm:JavaScript包管理工具

在JavaScript的生态系统中&#xff0c;npm&#xff08;Node Package Manager&#xff09;无疑是一个举足轻重的存在。它不仅是Node.js的包管理器&#xff0c;更是前端开发不可或缺的一部分&#xff0c;为开发者提供了丰富的包资源、便捷的包管理以及强大的社区支持。本文将深入…

EMS专题 | 守护数据安全:数据中心和服务器机房环境温湿度监测

您需要服务器机房温度监测解决方案吗&#xff1f; 服务器机房是企业中用于存储、管理和维护服务器及其相关组件的设施。服务器机房通常位于数据中心内&#xff0c;是一个专门设计的物理环境&#xff0c;旨在确保服务器的稳定运行和数据的安全性。服务器机房主要起到存储和管理数…

ES6的高阶语法特性

一、模板字符串的高级用法 1.1.模板字符串的嵌套 模板字符串的嵌套允许在一个模板字符串内部再嵌入一个或多个模板字符串。这种嵌套结构在处理复杂数据结构或生成具有层级关系的文本时非常有用。 1. 嵌套示例 假设我们有一个包含多个对象的数组&#xff0c;每个对象都有名称、…