ThinkPHP关联模型详解
在ThinkPHP中,关联模型更类似一种mysql中的外键约束,但是外键约束更加安全,缺点却是在写sql语句的时候不方便,ThinkPHP很好得解决了这个问题.但是很多人不动关联模型的意思.现在就写个例子.让大家理解ThinkPHP关联模型的意思.
环境描述:公司有一个员工表think_user,一个档案表,think_archives,一个部门表,think_department,和一个银行卡表.think_cars.
一个员工只有一个档案表,所以关系就是HSA_ONE,
一个员工只属于一个部门,但是部门里有多个员工,所以是BELONGS_TO关系
一个员工有多个银行卡,但是一个银行卡只能属于一个员工.所以关系就是HAS_MANY.
先创建需要的表和测试数据
think_user员工表
CREATE TABLE `think_user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`username` varchar(50) NOT NULL,
`password` varchar(50) NOT NULL,
`did` int(11) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |
think_department部门表
CREATE TABLE `think_department` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(50) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |
think_archives档案表
CREATE TABLE `think_archives` (
`id` int(7) NOT NULL AUTO_INCREMENT,
`uid` int(11) NOT NULL,
`addr` varchar(200) DEFAULT NULL,
`email` varchar(30) DEFAULT NULL,
`tel` int(13) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |
think_cars银行卡表
CREATE TABLE `think_cars` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(50) DEFAULT NULL,
`type` varchar(50) DEFAULT NULL,
`uid` int(11) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
插入数据到部门表think_department
insert into think_cars values
(null,'gongxiang','工商卡','1'),
(null,'jianshe','建行卡','2'),
(null,'jiaohang','交通银行卡',3);
think_user数据
insert into think_archives values
(null,1,'北京','123@163.com','13888888'),
(null,2,'上海','111@qq.com','1377777'),
(null,3,'重庆','222@qq.com','1344444'),
(null,4,'天津','333@qq.com','1111111'),
(null,5,'山西','444@qq.com','1322222'),
(null,6,'河北','555@qq.com','1333333'),
(null,7,'广州','6666@qq.com','13232323'),
(null,8,'广东','7777@qq.com','121121212'),
(null,9,'深证','888@qq.com','1821212');
think_cars数据
insert into think_cars values
(null,'gongxiang','工商卡','1'),
(null,'jianshe','建行卡','2'),
(null,'jiaohang','交通银行卡',3);
Query OK, 3 rows affected (0.01 sec)
think_archives
insert into think_archives values
(null,1,'北京','123@163.com','13888888'),
(null,2,'上海','111@qq.com','1377777'),
(null,3,'重庆','222@qq.com','1344444'),
(null,4,'天津','333@qq.com','1111111'),
(null,5,'山西','444@qq.com','1322222'),
(null,6,'河北','555@qq.com','1333333'),
(null,7,'广州','6666@qq.com','13232323'),
(null,8,'广东','7777@qq.com','121121212'),
(null,9,'深证','888@qq.com','1821212');
ok,数据和表创建完了,下面讲如何用ThinkPHP的关联模型去获取表中数据
现在Model文件夹里创建UserModel.class.php
<?php
class UserModel extend RelationModel{}
先做部门和员工之间的关系.员工表的did和部门表的id对应
class UserModel extends RelationModel{
protected $_link=array(
'Department'=>array(
'mapping_type'=>BELONGS_TO,
'class_name'=>'Department',
'mapping_name'=>'Department',
'foreign_key'=>'did',
),
);
}
mapping_type是要关联的模型类名
mapping_name 关联表的模型名称
foreign_key 关联表的外键定义
mapping_fields 关联表要查询的字段,默认为全部字段
condition 关联条件
parent_key 自引用关联字段
as_fields 字段别名定义
2.员工表和档案表之间的关系
protected $_link=array(
'Archives'=>array(
'mapping_type'=>HAS_ONE,
'class_name'=>'Archives',
'foreign_key'=>'id',
'condition'=>'uid'
),
);
3.员工表与银行卡表之间关系的定义
protected $_link=array(
'Cars'=>array(
'mapping_type'=>HAS_MANY,
'class_name'=>'Cars',
'foreign_key'=>'id',
'condition'=>'uid',
),
);
使用方法,在IndexAction.class.php中
class IndexAction extends Action {
public function index(){
$user=D('User');
$row=$user->relation(true)->select();
dump($row);
}
}
ThinkPHP关联模型详解的更多相关文章
- ThinkPHP第十四天(显示TRACE界面配置,关联模型详解定义)
1.显示TRACE界面,首选需要在显示模版界面,$this->display(),然后需要在配置文件中配置 SHOW_PAGE_TRACE => true 2.关联模型使用 主表以user ...
- ThinkPHP视图查询详解
ThinkPHP视图查询详解 参考http://www.jb51.net/article/51674.htm 这篇文章主要介绍了ThinkPHP视图查询,需要的朋友可以参考下 ThinkP ...
- JVM的类加载过程以及双亲委派模型详解
JVM的类加载过程以及双亲委派模型详解 这篇文章主要介绍了JVM的类加载过程以及双亲委派模型详解,类加载器就是根据指定全限定名称将 class 文件加载到 JVM 内存,然后再转化为 class 对象 ...
- ASP.NET Core的配置(2):配置模型详解
在上面一章我们以实例演示的方式介绍了几种读取配置的几种方式,其中涉及到三个重要的对象,它们分别是承载结构化配置信息的Configuration,提供原始配置源数据的ConfigurationProvi ...
- ThinkPHP 关联模型(二十)
原文:ThinkPHP 关联模型(二十) ThinkPHP关联模型 两表关联查询:Message 和 user 关联条件uid(参考手册:模型->关联模型) 步骤: 一:创建Message表 ...
- ISO七层模型详解
ISO七层模型详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 在我刚刚接触运维这个行业的时候,去面试时总是会做一些面试题,笔试题就是看一个运维工程师的专业技能的掌握情况,这个很 ...
- 28、vSocket模型详解及select应用详解
在上片文章已经讲过了TCP协议的基本结构和构成并举例,也粗略的讲过了SOCKET,但是讲解的并不完善,这里详细讲解下关于SOCKET的编程的I/O复用函数. 1.I/O复用:selec函数 在介绍so ...
- 第94天:CSS3 盒模型详解
CSS3盒模型详解 盒模型设定为border-box时 width = border + padding + content 盒模型设定为content-box时 width = content所谓定 ...
- ThinkPHP关联模型如何关联非主键
ThinkPHP关联模型默认是主键外键关联 官方并没有提供相关文档 如何实现非主键与非主键间之间的关联 <?php namespace Admin\Model; use Think\Model\ ...
随机推荐
- Python使用XML操作mapnik,实现复杂标注(Multi line text symbolizer)
test.py import mapnik stylesheet = 'world_style.xml' image = 'world_style.png' m = mapnik.Map(1200, ...
- 安装caffe碰到的坑(各种.so未找到)
./include/caffe/common.hpp:4:32: fatal error: boost/shared_ptr.hpp: 没有那个文件或目录 所有类似于上面的错误,都可以用如下格式来解决 ...
- CentOS8 中文输入法
CentOS8发布了,安装了下试试,结果发现中文输入法调不出来. 系统安装完成后,在系统[设置]的[Region&Language]里的[输入源]里可以添加汉语输入源,但是不能打中文字. 下面 ...
- 判断字符串a是否以字符串b开头或结尾
使用字符串的 str.startwith() 和 str.endswith()方法 import os , stat for name in os.listdir('.') if name.endsw ...
- Applied Spatiotemporal Data Mining应用时空数据挖掘
Course descriptionWith the continuing advances of geographic information science and geospatialtechn ...
- springboot(四).配置FastJson自定义消息转化器
配置FastJson自定义消息转化器 一.fastJson简介 fastJson是阿里巴巴旗下的一个开源项目之一,顾名思义它专门用来做快速操作Json的序列化与反序列化的组件.它是目前json解析最快 ...
- 时间戳Unix和时间之间的转换
时间戳 ---> 时间 var a="1523258178"; var start = new Date(a).format("yyyy-MM-dd hh:mm ...
- 【错误记录】windows python 路径中的一个转义错误:'rawunicodeescape' codec can't decode bytes in position 112-113: truncated \uXXXX
ur"D:\work\结构化\CSV\useful\内容.csv" 报错 编码错误原因,当路径中有\u这种字串时,即使是包含在r"" 中也会进行转义,然后转义出 ...
- 第十周java学习总结
目录 第十周java学习总结 学习内容 代码上传截图 代码链接 第十周java学习总结 学习内容 第12章 Java多线程机制 主要内容 Java中的线程 Thread类与线程的创建 线程的常用方法 ...
- Arthas随笔
目录 Arthas 安装Java 安装 Arthas Arthas 命令及示例 源码分析 Arthas 安装Java 下载jdk 注意 下载的JDK版本要与linux操作系统相匹配,否则汇报No su ...