关联定义

一对多关联的情况也比较常见,使用hasMany方法定义,参数包括:

hasMany('关联模型名','外键名','主键名',['模型别名定义']);

例如租客表和宿舍表,一个宿舍有多个租客,宿舍和租客一对多的关系,表结构如下:

#宿舍
CREATE TABLE `apartment` (
`apar_id` int(11) NOT NULL AUTO_INCREMENT COMMENT '编号',
`apar_name` varchar(40) DEFAULT NULL COMMENT '名称',
`apar_type` varchar(20) DEFAULT NULL COMMENT '类型',
`apar_price` varchar(30) DEFAULT NULL COMMENT '价格',
`apar_sum` int(11) DEFAULT NULL COMMENT '床数',
PRIMARY KEY (`apar_id`)
) COMMENT='宿舍'; #租客
CREATE TABLE `client` (
`cli_id` int(11) NOT NULL AUTO_INCREMENT COMMENT '编号',
`aid` int(11) DEFAULT NULL COMMENT '外键', #房间
`cli_name` varchar(20) DEFAULT NULL COMMENT '姓名',
`cli_sex` varchar(20) DEFAULT NULL COMMENT '性别',
`cli_phone` varchar(40) DEFAULT NULL COMMENT '电话',
`cli_identity` varchar(50) DEFAULT NULL COMMENT '身份证',
`cli_reservation` varchar(40) DEFAULT NULL COMMENT '预定房间',
PRIMARY KEY (`cli_id`),
KEY `Apar_id` (`aid`),
CONSTRAINT `client_ibfk_1` FOREIGN KEY (`aid`) REFERENCES `apartment` (`apar_id`)
) COMMENT='租客';

宿舍表的模型用hasMany方法,这样已经关联租客表:

<?php
namespace app\demo\model;
use think\Model;
//宿舍
class Apartment extends Model
{
//定义关联方法
public function comm(){
//hasMany('租客表名','租客表外键','宿舍主键',['模型别名定义']);
return $this->hasMany('client','aid','apar_id');
}
}

关联查询

我们可以通过下面的方式获取关联数据:

    //方法一:这个需要调用$apr->comm才查顾客表
$apr = Apartment::get(1);
$apr->comm;//注意这里不加括号
//方法二:不用调用$apr->comm,预先查租客表
$apr = Apartment::get(1,'comm');

注:comm是一个属性,这里先执行comm()把里面的租客信息封装到comm;comm()是关联模型,comm返回是租客的信息

根据关联条件查询

    //根据关联条件查询
$apr = Apartment::get(1);
$data = $apr->comm()->where('cli_name','陈芬')->select();
print_r($data);
//或者使用getBy
$apr = Apartment::get(1);
$data = $apr->comm()->getByCliName('陈芬');
print_r($data);

关联聚合查询

      //聚合查询,默认查询宿舍的租客人数'>='1的宿舍
$apr = Apartment::has('comm')->select();
//查询宿舍的租客人数'>='3的宿舍
$apr = Apartment::has('comm','>=','3')->where('apar_name','410')->select();
print_r($apr);

也可以查询全部宿舍和全部租客相关联的信息 ,如下:

        //方法一:获取全部数据
$apr = Apartment::all();
foreach ($apr as $list) {
//$list->comm封装全部租客的信息,一个宿舍有多个租客
foreach ($list->comm as $ac){
echo "姓名:{$ac->cli_name},房号:{$list->apar_name}<br>";
}
}
//方法二:使用关联预查询功能,有效提高性能。
$apr = Apartment::with('comm')->select();
foreach ($apr as $list) {
//$list->comm封装全部租客的信息,一个宿舍有多个租客
foreach ($list->comm as $ac){
echo "姓名:{$ac->cli_name},房号:{$list->apar_name}<br>";
}
}

关联新增

      //新增,添加一位租客
$apr = Apartment::get(1);
$cli = new Client();
$cli->cli_name = "小唐";
$cli->cli_sex = '男';
$cli->cli_phone='1315***';
$cli->cli_identity='4487654334567610';
$cli->cli_reservation='没有';
$apr->comm()->save($cli);

如果想批量新增,如下:

//批量新增租客
$apr = Apartment::get(2);
$cli = [
["cli_name"=>'阿K','cli_sex'=>'男','cli_phone'=>'1315***','cli_identity'=>'448***','cli_reservation'=>'没有'],
["cli_name"=>'小胡','cli_sex'=>'男','cli_phone'=>'1315***','cli_identity'=>'448***','cli_reservation'=>'没有']
];
$apr->comm()->saveAll($cli);

关联更新

        //更新
$apr = Apartment::get(1);
$comm = $apr->comm()->getByCliName('陈杨文');
$comm->cli_name='杨文';
$comm->save();
//或者通过update方法更新
$apr = Apartment::get(1);
$apr->comm()->where('cli_id',5)->update(['cli_name'=>'陈杨文']);

关联删除

        //删除id为13的租客
$apr = Apartment::get(2);
$comm = $apr->comm()->getByCliId(13);
$comm->delete();
//删除所有的关联数据
$apr = Apartment::get(2);
$apr->$comm()->delete();

ThinkPHP5——模型关联(一对多关联)的更多相关文章

  1. 后盾网lavarel视频项目---模型一对多关联简单实例

    后盾网lavarel视频项目---模型一对多关联简单实例 一.总结 一句话总结: 在模型中定义一个方法来设置一对多关联:return $this->hasMany(Video::class); ...

  2. 后盾网lavarel视频项目---lavarel多表关联一对多操作实例

    后盾网lavarel视频项目---lavarel多表关联一对多操作实例 一.总结 一句话总结: 1.一对多中多那个部分的数据前端通过json弄到服务器 2.所有通过一操作多的时候,都要用上模型中定义的 ...

  3. TP5一对一、一对多关联模型的使用

    文章表SQL CREATE TABLE `tp_article` ( `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键ID', `title` varc ...

  4. ThinkPHP5——模型关联(多对多关联)

    关联定义 多对多关联不像一对一和一对多关联,它还要多建一个中间表用来处理多对多的关联,例如: #城市 create table city ( c_id int primary key AUTO_INC ...

  5. thinkphp5 模型表关联

    student 表 外键 grade_idgrade 表主键 id在 模型中student表关联方法public function Grade(){ return $this->hasOne(' ...

  6. ThinkPHP5——模型关联(一对一关联)

    定义 定义一对一关联使用了hasOne,hasOne方法的参数包括: hasOne('关联模型名','外键名','主键名',['模型别名定义'],'join类型'); 下面定义一个用户表,公司给每个用 ...

  7. 深入理解 Laravel Eloquent(三)——模型间关系(关联)

    Eloquent是什么 Eloquent 是一个 ORM,全称为 Object Relational Mapping,翻译为 "对象关系映射"(如果只把它当成 Database A ...

  8. [转]NHibernate之旅(10):探索父子(一对多)关联查询

    本节内容 关联查询引入 一对多关联查询 1.原生SQL关联查询 2.HQL关联查询 3.Criteria API关联查询 结语 关联查询引入 在NHibernate中提供了三种查询方式给我们选择:NH ...

  9. Ruby on Rails,一对多关联(One-to-Many)

    在上一篇文章中,我们知道通过has_one和belongs_to方法定义一对一关联关系.接下来是更常见的情况,一对多关联.比如老师与所教课程的关系,一个老师负责多个课程.换成对象之间的关系就是:一个老 ...

随机推荐

  1. [考试反思]0904NOIP模拟测试37:守望

    100分并列的还有4个没粘 总分是大脸的一半,然而还只低了2名.差距好大...但其实后面的分数段又很密集,和我都差不了多少... 我可能也是最水的那一个,排行榜前7个里面就我没有AC.全是暴力... ...

  2. javaScript中this到底指向谁

    1.前言 在JavaScript中,this的指向一直是大多数初学者的易错点,总是搞不清楚this到底指向谁,而在求职面试中,this的指向问题往往又是高频考点.本篇博文就来总结一下在JavaScri ...

  3. Java基础系列4:抽象类与接口的前世今生

    该系列博文会告诉你如何从入门到进阶,一步步地学习Java基础知识,并上手进行实战,接着了解每个Java知识点背后的实现原理,更完整地了解整个Java技术体系,形成自己的知识框架. 1.抽象类: 当编写 ...

  4. 清空 npm 缓存

    清空 npm 缓存 npm cache clean -f

  5. 算法编程题积累(3)——腾讯笔试"构造回文“问题

    首先理解题意,回文串的特点:倒序后跟原串相同.故而可以将原串看成向一个回文串在任意位置添加任意字符后形成的字符串,也就是说原串中存在一段未必连续的回文序列. 通过分析可以知道AC本题的核心思路:求出回 ...

  6. MySQL 执行计划详解

    我们经常使用 MySQL 的执行计划来查看 SQL 语句的执行效率,接下来分析执行计划的各个显示内容. EXPLAIN SELECT * FROM users WHERE id IN (SELECT ...

  7. ios沙盒机制---基本数据类型的存取和文件的基本操作

    沙盒快速存储及读取 存储:  [[NSUserDefaults standardUserDefaults] setObject:@"abc" forKey:@"1&quo ...

  8. [LC]783题 二叉搜索树结点最小距离(中序遍历)

    ①题目 给定一个二叉搜索树的根结点 root, 返回树中任意两节点的差的最小值. 示例: 输入: root = [4,2,6,1,3,null,null]输出: 1解释:注意,root是树结点对象(T ...

  9. Linux命令大全(个人整理,如不全面望谅解)

    系统信息 arch 显示机器的处理器架构(1) uname -m 显示机器的处理器架构(2) uname -r 显示正在使用的内核版本 dmidecode -q 显示硬件系统部件 - (SMBIOS ...

  10. nyoj 242-计算球体积 (pi*r*r*r*4/3)

    242-计算球体积 内存限制:64MB 时间限制:3000ms 特判: No 通过数:21 提交数:74 难度:1 题目描述: 根据输入的半径值,计算球的体积. 输入描述: 输入数据有多组,每组占一行 ...