thinkphp5.1模型关联 -- 一对一关联

2023-12-07 22:48

本文主要是介绍thinkphp5.1模型关联 -- 一对一关联,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

下面两个是关联表:test_user表和test_profile表,关联字段为:test_profile表中的user_id字段关联test_user表中的id字段

 模型:User.php中的代码如下:

<?phpnamespace app\index\model;
use think\Model;class User extends Model
{protected $table = 'test_user';protected $pk = 'id';//这里的方法名可以随意取,只要不冲突即可public function profile(){return $this->hasOne('Profile','user_id');}
}

 模型:Pofile.php中的代码如下:

<?php
namespace app\index\model;use think\Model;class Profile extends Model
{protected $table = 'test_profile';protected $pk = 'id';public function returnUser(){return $this->belongsTo('User','user_id');}}

控制器index.php中的代码如下:

<?php
namespace app\index\controller;use think\Controller;
use think\Db;
use app\index\model\User;
use app\index\model\Profile;class Index extends Controller
{public function index(){/*对比以下两个查询方法,加深对一对一关联查询的理解*///通过test_profile表中用户昵称是"及时雨"这个条件,查询test_user表中符合条件的数据$user = User::hasWhere('profile', ['nickname' => '及时雨'])->select();//通过test_user表中用户名是"李师师"这个条件,反过来查询test_profile表中符合条件的数据$pro = Profile::hasWhere('returnUser', ['username' => '李师师'])->select();//通过查询test_user表中id是7的记录,获取该条记录的用户昵称$pro2 = User::get(7);$nickname = $pro2->profile->nickname;//切记这里的$pro2->profile可千万不要写成了:$pro2->profile()。不能加括号,因为模型关联的时候,他相当于把profile当做了类的属性,虽然看上去是模型中的方法,但是他是按照获取属性的方式获取的echo '<pre>';print_r($user);print_r($pro);print_r($nickname);}public function index2(){//第一种:预载入查询$users = User::with('profile')->select();foreach ($users as $user) {echo $user->profile->nickname . '</br>';}/*产生的sql语句SELECT * FROM `test_user`SELECT * FROM `test_profile` WHERE  `user_id` IN (1,2,3,4,5,6,7,8)*///如果要对关联模型进行约束,可以使用闭包的方式。$users = User::with(['profile' => function ($query) {$query->where('nickname', '及时雨')->whereOr('nickname', '行者');}])->select();foreach ($users as $user) {echo $user->profile->nickname;}/**产生的sql语句SELECT * FROM `test_user`SELECT * FROM `test_profile` WHERE  `nickname` = '及时雨'  AND `user_id` IN (1,2,3,4,5,6,7,8) OR `nickname` = '行者'*///第二种:$users = User::select();foreach ($users as $user) {echo $user->profile->nickname . '</br>';}/*产生的sql语句SELECT * FROM `test_user`SELECT * FROM `test_profile` WHERE  `user_id` = 1 LIMIT 1SELECT * FROM `test_profile` WHERE  `user_id` = 2 LIMIT 1SELECT * FROM `test_profile` WHERE  `user_id` = 3 LIMIT 1SELECT * FROM `test_profile` WHERE  `user_id` = 4 LIMIT 1SELECT * FROM `test_profile` WHERE  `user_id` = 5 LIMIT 1SELECT * FROM `test_profile` WHERE  `user_id` = 6 LIMIT 1SELECT * FROM `test_profile` WHERE  `user_id` = 7 LIMIT 1SELECT * FROM `test_profile` WHERE  `user_id` = 8 LIMIT 1*/}public function index3(){//第一种:预载入查询$users = User::with('profile')->select();foreach ($users as $user) {echo $user->profile->nickname . '</br>';}/*如果User.php中   return $this->hasOne('Profile','user_id')->setEagerlyType(0);或者 如果User.php中   return $this->hasOne('Profile','user_id');产生的sql语句SELECT * FROM `test_user`SELECT * FROM `test_profile` WHERE  `user_id` IN (1,2,3,4,5,6,7,8)*//*如果User.php中return $this->hasOne('Profile','user_id')->setEagerlyType(0);产生的sql语句SELECT `user`.`id`,`user`.`user_group_id`,`user`.`username`,`user`.`password`,`profile`.`id` AS `profile__id`,`profile`.`user_id` AS `profile__user_id`,`profile`.`nickname` AS `profile__nickname`,`profile`.`sex` AS `profile__sex` FROM `test_user` `user` INNER JOIN `test_profile` `profile` ON `user`.`id`=`profile`.`user_id`*///===================================================================////使用withJoin()方法,就是用'join'方式,这$users = User::withJoin('profile')->select();foreach ($users as $user) {echo $user->profile->nickname . '</br>';}/**SELECT `user`.`id`,`user`.`user_group_id`,`user`.`username`,`user`.`password`,`profile`.`id` AS `profile__id`,`profile`.`user_id` AS `profile__user_id`,`profile`.`nickname` AS `profile__nickname`,`profile`.`sex` AS `profile__sex` FROM `test_user` `user` INNER JOIN `test_profile` `profile` ON `user`.`id`=`profile`.`user_id`*/$users = User::withJoin('profile','LEFT')->select();foreach ($users as $user) {echo $user->profile->nickname . '</br>';}/**SELECT `user`.`id`,`user`.`user_group_id`,`user`.`username`,`user`.`password`,`profile`.`id` AS `profile__id`,`profile`.`user_id` AS `profile__user_id`,`profile`.`nickname` AS `profile__nickname`,`profile`.`sex` AS `profile__sex` FROM `test_user` `user` LEFT JOIN `test_profile` `profile` ON `user`.`id`=`profile`.`user_id`*///===================================================================////$res = User::get(8)->profile->save(['nickname'=>'孝义','sex'=>'男']);//编辑操作$res = User::get(8)->profile()->save(['nickname'=>'孝义','sex'=>'男']);//新增操作var_dump($res);die;//===================================================================////反过来,根据关联模型test_profile表的信息,获取test_user表的的对应的信息return Profile::get(7)->returnUser->username;//===================================================================////模型绑定:就是在输出父模型数据表中的字段时,同时还输出绑定到父模型中的关联模型中的字段//如下:因为User.php中, return $this->hasOne('Profile','user_id')->bind('nickname');把'nickname'字段绑定到了父模型下,所以在输出父模型test_user表中的字段时,同时还会输出绑定到该模型下在test_profile表中的nickname字段$user = User::get(1, 'profile');echo '<pre>';print_r($user);echo $user->nickname;die;}

 

这篇关于thinkphp5.1模型关联 -- 一对一关联的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/467623

相关文章

MySQL复合查询从基础到多表关联与高级技巧全解析

《MySQL复合查询从基础到多表关联与高级技巧全解析》本文主要讲解了在MySQL中的复合查询,下面是关于本文章所需要数据的建表语句,感兴趣的朋友跟随小编一起看看吧... 目录前言:1.基本查询回顾:1.1.查询工资高于500或岗位为MANAGER的雇员,同时还要满足他们的姓名首字母为大写的J1.2.按照部门

SQL表间关联查询实例详解

《SQL表间关联查询实例详解》本文主要讲解SQL语句中常用的表间关联查询方式,包括:左连接(leftjoin)、右连接(rightjoin)、全连接(fulljoin)、内连接(innerjoin)、... 目录简介样例准备左外连接右外连接全外连接内连接交叉连接自然连接简介本文主要讲解SQL语句中常用的表

如何高效移除C++关联容器中的元素

《如何高效移除C++关联容器中的元素》关联容器和顺序容器有着很大不同,关联容器中的元素是按照关键字来保存和访问的,而顺序容器中的元素是按它们在容器中的位置来顺序保存和访问的,本文介绍了如何高效移除C+... 目录一、简介二、移除给定位置的元素三、移除与特定键值等价的元素四、移除满足特android定条件的元

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

Java的IO模型、Netty原理解析

《Java的IO模型、Netty原理解析》Java的I/O是以流的方式进行数据输入输出的,Java的类库涉及很多领域的IO内容:标准的输入输出,文件的操作、网络上的数据传输流、字符串流、对象流等,这篇... 目录1.什么是IO2.同步与异步、阻塞与非阻塞3.三种IO模型BIO(blocking I/O)NI

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

mysql关联查询速度慢的问题及解决

《mysql关联查询速度慢的问题及解决》:本文主要介绍mysql关联查询速度慢的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql关联查询速度慢1. 记录原因1.1 在一次线上的服务中1.2 最终发现2. 解决方案3. 具体操作总结mysql

C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)

《C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)》本文主要介绍了C#集成DeepSeek模型实现AI私有化的方法,包括搭建基础环境,如安装Ollama和下载DeepS... 目录前言搭建基础环境1、安装 Ollama2、下载 DeepSeek R1 模型客户端 ChatBo

SpringBoot快速接入OpenAI大模型的方法(JDK8)

《SpringBoot快速接入OpenAI大模型的方法(JDK8)》本文介绍了如何使用AI4J快速接入OpenAI大模型,并展示了如何实现流式与非流式的输出,以及对函数调用的使用,AI4J支持JDK8... 目录使用AI4J快速接入OpenAI大模型介绍AI4J-github快速使用创建SpringBoot

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应