iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > PHP编程 >ThinkPHP的查询关联功能怎么用
  • 444
分享到

ThinkPHP的查询关联功能怎么用

2023-07-06 01:07:07 444人浏览 泡泡鱼
摘要

本文小编为大家详细介绍“ThinkPHP的查询关联功能怎么用”,内容详细,步骤清晰,细节处理妥当,希望这篇“Thinkphp的查询关联功能怎么用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一. 模型关联1.1一

本文小编为大家详细介绍“ThinkPHP的查询关联功能怎么用”,内容详细,步骤清晰,细节处理妥当,希望这篇“Thinkphp的查询关联功能怎么用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

一. 模型关联

1.1一对一关联

一对一关联即两个数据表中各自只有一条记录,这时使用hasOne()和belongTo()函数进行关联。假设我们有两个表,一个是user表,一个是userinfo表,两张表的结构如下:

user:idnameuserinfo:iduser_idage

上面两个表是通过字段user_id进行关联的。我们现在要查找user表的用户信息以及该用户的年龄,具体操作如下:

在User模型中定义一个userinfo()方法,方法名随意。

//User模型<?phpclass User extends Model{public function userinfo(){return $this -> hasOne('UserInfo', 'user_id');}}

在User模型中定义一个age()方法,这个方法其实是定义了一个属性,它访问userinfo模型的age字段。

//User模型<?phpclass User extends Model{protected $readonly = ['age'];public function userinfo(){return $this -> hasOne('UserInfo', 'user_id');}public function getAgeAttr($value, $data){if(isset($data['userinfo'])){return $data['userinfo']['age'];}return '';}}

完成以上代码后,我们就可以使用find()方法查询到我们想要的用户以及其年龄:

//查询user表中id为1的用户$user = User::get(1);echo $user -> name;echo $user -> age;

注意:在上面的代码中,我们使用了$readonly属性,$readonly属性是ThinkPHP提供的属性,他能够保护一些属性不被写入数据库。在上面的代码中,我们将age属性设定为只读属性,这样当$user -> age被访问的时候,就会自动调用getAgeAttr方法去查询userinfo模型里面的age字段。

1.2 一对多关联

一对多关联指的是两个数据表中一个有多条记录,一个只有一条记录。如下面的例子:

order:iduser_idorder_noorder_Goods:idorder_idnameprice

上面两个表是通过字段order_id关联的。我们现在要查找user表中用户的订单信息以及对应的商品信息,具体操作如下:

在User模型中定义一个orders()方法,这个方法表示一个用户有多个订单。

//User模型<?phpclass User extends Model{public function orders(){return $this -> hasMany('Order', 'user_id');}}

在Order模型中定义一个goods()方法,这个方法表示一个订单有多个商品。

//Order模型<?phpclass Order extends Model{public function goods(){return $this -> hasMany('OrderGoods', 'order_id');}}

定义好以上的关联后,我们就可以使用find()方法查询出用户的订单以及每个订单对应的商品:

//查询user表中id为1的用户的订单信息和订单的商品信息$user = User::get(1, 'orders.goods');var_dump($user -> orders[0] -> goods);

最后一个参数('orders.goods')表示同时查询它所有的Order和Order关联的Goods信息。

二. 查询关联

2.1 使用关联查询

除了在模型层次上定义关联关系之外,我们还可以通过调用模型层的关联属性来实现关联查询。如,我们现在想查询一个用户以及它的订单信息:

$user = User::get(1);$orders = $user -> orders;echo $user -> name;foreach($orders as $order){echo $order -> order_no . "\n";}

2.2 延迟关联

如果我们不想在查询一个模型的时候自动查询它的关联关系,可以使用延迟关联来实现此需求。如:

$user = User::with('orders')->get(1);

上面的代码中,我们设置$user变量时在with()函数中定义了所要获取的关联关系,这时查询语句不会默认自动查询关联关系,而是等待我们使用关联关系时才会查询。

2.3 包含关联

除了上面的延迟关联外,我们还可以通过设置with方法后的true参数自动包含所有关联关系来实现我们的查询需求。如:

$user = User::with('orders')->find(1, true);

上面的代码中,我们在find()方法中增加了一个true参数,这个参数表示我们要包含user模型的所有关联关系。

读到这里,这篇“ThinkPHP的查询关联功能怎么用”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网PHP编程频道。

--结束END--

本文标题: ThinkPHP的查询关联功能怎么用

本文链接: https://www.lsjlt.com/news/356881.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • ThinkPHP的查询关联功能怎么用
    本文小编为大家详细介绍“ThinkPHP的查询关联功能怎么用”,内容详细,步骤清晰,细节处理妥当,希望这篇“ThinkPHP的查询关联功能怎么用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一. 模型关联1.1一...
    99+
    2023-07-06
  • Thinkphp 6.0多对多关联查询
    本节课我们来了解关联模型中,多对多的关联查询以及新增删除等操作。 一.多对多关联 1. 复习一下一对一,一个用户对应一个用户档案资料,是一对一关联; 2. 复习一下一对多,一篇文章对应多个评论,是一对多关联;...
    99+
    2023-09-05
    php 数据库 mysql
  • ThinkPHP多表联合查询怎么用
    这篇文章主要介绍ThinkPHP多表联合查询怎么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!thinkphp是什么thinkphp属于一种免费的开发框架,能够用于开发前端网页,最早thinkphp是为了简化开发而...
    99+
    2023-06-14
  • thinkphp关联查询怎么简化数据结构
    本篇内容主要讲解“thinkphp关联查询怎么简化数据结构”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“thinkphp关联查询怎么简化数据结构”吧!一、什么是ThinkPHP关联查询关联查询可...
    99+
    2023-07-06
  • mybatis-plus多表关联查询功能的实现
    学习目标: mybatis-plus多表关联查询 学习内容: mybatis-plus多表关联查询 实体类部分代码 @Data @AllArgsConstructor @NoAr...
    99+
    2024-04-02
  • mybatisplus 的SQL拦截器实现关联查询功能
    由于项目中经常会使用到一些简单地关联查询,但是mybatisplus还不支持关联查询,不过在看官方文档的时候发现了mybatisplus的SQL拦截器(其实也是mybatis的)就想...
    99+
    2024-04-02
  • Mongodb实现的关联表查询功能【population方法】
    本文实例讲述了Mongodb实现的关联表查询功能。分享给大家供大家参考,具体如下: Population MongoDB是非关联数据库。但是有时候我们还是想引用其它的文档。这就是population的用武之...
    99+
    2024-04-02
  • thinkphp关联查询如何使用条件进行筛选
    这篇“thinkphp关联查询如何使用条件进行筛选”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“thinkphp关联查询如何...
    99+
    2023-07-05
  • MySQL中的多表联合查询功能怎么使用
    本篇内容介绍了“MySQL中的多表联合查询功能怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一.介绍多表查询就是同时查询两个或两个以...
    99+
    2023-07-05
  • 怎么在mybatisplus 中使用SQL拦截器实现关联查询功能
    本篇文章为大家展示了怎么在mybatisplus 中使用SQL拦截器实现关联查询功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。环境信息jdk: 1.8springboot: 2.3.4.RELE...
    99+
    2023-06-15
  • 关于JpaRepository的关联查询和@Query查询
    目录一 pom二 启动类三 配置文件四 新建数据库五 实体类1 Clazz2 Student六 控制器七 Repository层1 ClazzRepository2 StudentR...
    99+
    2024-04-02
  • ThinkPHP中join关联查询如何不使用默认的表前缀
    小编给大家分享一下ThinkPHP中join关联查询如何不使用默认的表前缀,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!php有什么特点1、执行速度快。2、具有很...
    99+
    2023-06-14
  • Mybatis_day05中怎么实现关联查询
    本篇文章给大家分享的是有关Mybatis_day05中怎么实现关联查询,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。 关联查询一对一...
    99+
    2024-04-02
  • Mybatis Plus关联查询怎么实现
    本篇内容介绍了“Mybatis Plus关联查询怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Mybatis-Plus 简介什么是 ...
    99+
    2023-06-22
  • sql怎么两个表关联查询
    在 SQL 中,我们可以使用 JOIN 关键字来两个表关联查询。例如,假设有两个表:table1 和 table2,并且它们之间有一个关联字段 field1。你可以使用如下的语句来两个表关联查询: SELECT * FROM t...
    99+
    2023-09-01
    sql 数据库 mysql
  • MySQL的多表关联查询
    一、多表关联查询 多表关联查询是使用一条SQL语句,将关联的多张表的数据查询出来。 1.1 交叉查询 交叉查询就是将多张表的数据没有条件地连接在一起进行展示。 1.1.1 语法 使用交叉查询类别和商品 -- 目标:查询所有分类,以及每个分类...
    99+
    2023-08-22
    mysql 数据库 java
  • 怎么使用PHP编写关联查询语句
    本篇内容主要讲解“怎么使用PHP编写关联查询语句”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么使用PHP编写关联查询语句”吧!一、什么是关联查询?关联查询是一种查询多个表中的数据,将它们组合...
    99+
    2023-07-05
  • oracle跨库关联查询怎么实现
    在Oracle中,可以使用以下几种方法实现跨库关联查询: 使用数据库链接(Database Link):首先在目标数据库中创建一个...
    99+
    2024-04-09
    oracle
  • Hibernate多表关联查询怎么实现
    本篇内容介绍了“Hibernate多表关联查询怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、Hibernate简介Hiberna...
    99+
    2023-06-17
  • MySQL中的多表联合查询功能操作
    目录一.介绍数据准备交叉连接查询 内连接查询外连接子查询特点子查询关键字all关键字any关键字和some关键字in关键字exists关键字 自关联查询总结 一.介绍 多表查询就是同时查询两个或两个以...
    99+
    2023-02-01
    mysql多表联合查询 mysql多表查询 mysql联合查询
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作