https://www.jb51.net/article/31381.htm
通常我们所说的关联关系包括下面三种:
◇ 一对一关联 : ONE\_TO\_ONE , 包括 HAS\_ONE 和 BELONGS\_TO
◇ 一对多关联 : ONE\_TO\_MANY , 包括 HAS\_MANY 和 BELONGS\_TO
◇ 多对多关联 : MANY\_TO\_MANY
**关联定义**
数据表的关联 CURD 操作,目前支持的关联关系包括下面四种:HAS\_ONE 、 BELONGS\_TO 、 HAS\_MANY 、 MANY\_TO\_MANY 。
一个模型根据业务模型的复杂程度可以同时定义多个关联,不受限制,所有的关联定义都统一在模型类的 $\_link 成员变量里面定义,并且可以支持动态定义。要支持关联操作,模型类必须继承 RelationModel 类,关联定义的格式是:
复制代码代码如下:
protected $\_link = array(
' 关联 1' => array(
' 关联属性 1' => ' 定义 ',
' 关联属性 N' => ' 定义 ',
),
' 关联 2' => array(
' 关联属性 1' => ' 定义 ',
' 关联属性 N' => ' 定义 ',
),
...
);
HAS\_ONE 关联方式的定义:
复制代码代码如下:
class UserModel extends RelationModel
{
public $\_link = array(
'Profile'=> array(
'mapping\_type' =>HAS\_ONE,
'class\_name'=>'Profile',
// 定义更多的关联属性
……
) ,
);
}
mapping\_type 关联类型,这个在 HAS\_ONE 关联里面必须使用 HAS\_ONE 常量定义。
class\_name 要关联的模型类名
mapping\_name 关联的映射名称,用于获取数据用
foreign\_key 关联的外键名称
condition 关联条件
mapping\_fields 关联要查询的字段
as\_fields 直接把关联的字段值映射成数据对象中的某个字段
BELONGS\_TO 关联方式的定义:
复制代码代码如下:
'Dept'=> array(
'mapping\_type'=>BELONGS\_TO,
'class\_name'=>'Dept',
'foreign\_key'=>'userId',
'mapping\_name'=>'dept',
// 定义更多的关联属性
……
) ,
class\_name 要关联的模型类名
mapping\_name 关联的映射名称,用于获取数据用
foreign\_key 关联的外键名称
mapping\_fields 关联要查询的字段
condition 关联条件
parent\_key 自引用关联的关联字段
as\_fields 直接把关联的字段值映射成数据对象中的某个字段
HAS\_MANY 关联方式的定义:
复制代码代码如下:
'Article'=> array(
'mapping\_type' =>HAS\_MANY,
'class\_name'=>'Article',
'foreign\_key'=>'userId',
'mapping\_name'=>'articles',
'mapping\_order'=>'create\_time desc',
// 定义更多的关联属性
……
) ,
class\_name 要关联的模型类名
mapping\_name 关联的映射名称,用于获取数据用
foreign\_key 关联的外键名称
parent\_key 自引用关联的关联字段
condition 关联条件
mapping\_fields 关联要查询的字段
mapping\_limit 关联要返回的记录数目
mapping\_order 关联查询的排序
MANY\_TO\_MANY 关联方式的定义:
复制代码代码如下:
"Group"=>array(
'mapping\_type'=>MANY\_TO\_MANY,
'class\_name'=>'Group',
'mapping\_name'=>'groups',
'foreign\_key'=>'userId',
'relation\_foreign\_key'=>'goupId',
'relation\_table'=>'think\_gourpUser'
)
class\_name 要关联的模型类名
mapping\_name 关联的映射名称,用于获取数据用
foreign\_key 关联的外键名称
relation\_foreign\_key 关联表的外键名称
mapping\_limit 关联要返回的记录数目
mapping\_order 关联查询的排序
relation\_table 多对多的中间关联表名称
关联查询
使用 relation 方法进行关联操作, relation 方法不但可以启用关联还可以控制局部关联操作,实现了关联操作一切尽在掌握之中。
$User = D( "User" );
$user = $User->realtion(true)->find(1);
输出 $user 结果可能是类似于下面的数据:
复制代码代码如下:
array(
'id'=>1,
'account'=>'ThinkPHP',
'password'=>'123456',
'Profile'=> array(
'email'=>'liu21st@gmail.com',
'nickname'=>'流年',
) ,
)
关联写入
复制代码代码如下:
$User = D( "User" );
$data = array();
$data\["account"\]="ThinkPHP";
$data\["password"\]="123456";
$data\["Profile"\]=array(
'email'=>'liu21st@gmail.com',
'nickname' =>' 流年 ',
) ;
$result = $User->relation(true)->add($user);
这样就会自动写入关联的 Profile 数据。
关联更新
复制代码代码如下:
$User = D( "User" );
$data\["account"\]= "ThinkPHP";
$data\["password"\]= "123456";
$data\["Profile"\]=array(
'email'=>'liu21st@gmail.com',
'nickname' =>' 流年 ',
) ;
$result =$User-> relation(true)->where(‘id=3')->save($data);
关联删除
$result =$User->relation(true)->delete( "3" );
- 空白目录1
- RBAC
- RBAC权限模型[完整]
- 你知道权限管理的RBAC模型吗?
- rbac 一个用户对应多个账号_如何设计一个强大的权限系统
- Postman 快速使用(设置环境变量)
- postman的使用方法详解!最全面的教程
- Postman常用的几个功能
- ThinkPHP项目总结
- thinkphp5 递归查询所有子代,查询上级,并且获取层级
- PHP原生项目之留言板
- 智慧校园
- PHP如何实现订单的延时处理详解
- VUE
- const {data:res} = await login(this.loginForm)
- Vue中的async和await的使用
- PHP实现消息推送(定时轮询)
- tp5 计算两个日期之间相差的天数
- 使用jquery的ajax方法获取下拉列表值
- jQuery实现select下拉框选中数据触发事件
- SetFocus 方法
- 快来了解下TP6中的超级函数app()!
- PHP socket 服务器框架 workerman
- 程序员如何才能成为独立开发者?
- PHP 错误处理
- php面向对象类中的$this,static,final,const,self及双冒号 :: 这几个关键字使用方法。
- 小白教你玩转php的闭包
- 关于TP6项目搭建的坑(多应用模式)
- ThinkPHP6.0 与5.0的差别及坑点
- axios在vue项目中的使用实例详解
- php中的类、对象、方法是指什么
- 聊一聊PHP的依赖注入(DI) 和 控制反转(IoC)
- 深入理解控制反转(IoC)和依赖注入(DI)
- Private,Public,Protected
- ThinkPHP5(目录,路径,模式设置,命名空间)
- 在 ThinkPHP6 中使用 Workerman
- 介绍thinkphp lock锁的使用和例子
- php中_initialize()函数与 __construct()函数的区别说明
- api接口数据-验证-整理
- api接口数据-验证-整理【续】
- TP6容易踩得坑【原创】
- TP6的日志怎么能记录详细的日志?
- 是否需要模型分层
- PHP面试题 全网最硬核面试题来了 2021年学习面试跳槽必备(一)
- MySQL单表数据量过千万,采坑优化记录,完美解决方案
- MySql表分区(根据时间timestamp)
- MySQL大表优化方案
- 闲言碎语
- 数据库外键的使用
- 深入理解thinkphp、laravel等框架中容器概念
- vue做前端,thinkphp6做后台,项目部署
- 简单MVC架构的PHP留言本
- TP5里面extend和vendor的区别
- 在mysql数据库中制作千万级测试表
- MySQL千万级的大表要怎么优化
- ThinkPHP关联模型操作实例分析
- lcobucci/jwt —— 一个轻松生成jwt token的插件
- RESTful API 设计指南
- MySQL如何为表字段添加索引
- ThinkPHP6.0快速开发手册(案例版)
- tp5 静态方法和普通方法的区别
- 数据字典功能
- mysql中的数据库ID主键的设置问题
- 基于角色的权限控制(django内置auth体系)
- RBAC系统经典五张表
- 什么是接口文档,如何写接口,有什么规范?
- thinkphp5.0自定义验证器