在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{}
  1. 先做部门和员工之间的关系.员工表的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关联模型详解的更多相关文章

  1. ThinkPHP第十四天(显示TRACE界面配置,关联模型详解定义)

    1.显示TRACE界面,首选需要在显示模版界面,$this->display(),然后需要在配置文件中配置 SHOW_PAGE_TRACE => true 2.关联模型使用 主表以user ...

  2. ThinkPHP视图查询详解

    ThinkPHP视图查询详解 参考http://www.jb51.net/article/51674.htm   这篇文章主要介绍了ThinkPHP视图查询,需要的朋友可以参考下     ThinkP ...

  3. JVM的类加载过程以及双亲委派模型详解

    JVM的类加载过程以及双亲委派模型详解 这篇文章主要介绍了JVM的类加载过程以及双亲委派模型详解,类加载器就是根据指定全限定名称将 class 文件加载到 JVM 内存,然后再转化为 class 对象 ...

  4. ASP.NET Core的配置(2):配置模型详解

    在上面一章我们以实例演示的方式介绍了几种读取配置的几种方式,其中涉及到三个重要的对象,它们分别是承载结构化配置信息的Configuration,提供原始配置源数据的ConfigurationProvi ...

  5. ThinkPHP 关联模型(二十)

    原文:ThinkPHP 关联模型(二十) ThinkPHP关联模型 两表关联查询:Message 和  user  关联条件uid(参考手册:模型->关联模型) 步骤: 一:创建Message表 ...

  6. ISO七层模型详解

    ISO七层模型详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 在我刚刚接触运维这个行业的时候,去面试时总是会做一些面试题,笔试题就是看一个运维工程师的专业技能的掌握情况,这个很 ...

  7. 28、vSocket模型详解及select应用详解

    在上片文章已经讲过了TCP协议的基本结构和构成并举例,也粗略的讲过了SOCKET,但是讲解的并不完善,这里详细讲解下关于SOCKET的编程的I/O复用函数. 1.I/O复用:selec函数 在介绍so ...

  8. 第94天:CSS3 盒模型详解

    CSS3盒模型详解 盒模型设定为border-box时 width = border + padding + content 盒模型设定为content-box时 width = content所谓定 ...

  9. ThinkPHP关联模型如何关联非主键

    ThinkPHP关联模型默认是主键外键关联 官方并没有提供相关文档 如何实现非主键与非主键间之间的关联 <?php namespace Admin\Model; use Think\Model\ ...

随机推荐

  1. [LOJ 6704] 健身计划

    问题描述 九条可怜是一个肥胖的女孩. 她最近长胖了,她想要通过健身达到减肥的目的,于是她决定每天做n次仰卧起坐以达到健身的目的. 她可以将这n次动作分为若干组完成,每一次完成ai次仰卧起坐,每做完一次 ...

  2. 12.python csv文件写入和读出

    import csv headers = ["class", "name", "sex", "height", &quo ...

  3. cast() 函数进行类型转换

    service_fee  字段定义:`service_fee`  decimal(14,4) NULL DEFAULT NULL COMMENT '手续费金额,含税' , 需求:service_fee ...

  4. Android使用SDKManager下载SDK速度慢 容易丢包和异常的解决办法

    第一步, SDK Manager启动之后,会先解析一些google的xml文件,会在Log里面打印出一些日志信息. 解析完之后,把日志全部拷贝到一个记事本里(这一步是因为日志窗口不支持查找),在里面查 ...

  5. (53)LINUX应用编程和网络编程之八Linux网络基础

    3.8.1.网络通信概述 3.8.1.1.从进程间通信说起:网络域套接字socket,网络通信其实就是位于网络中不同主机上面的2个进程之间的通信. 3.8.1.2.网络通信的层次 (1)硬件部分:网卡 ...

  6. [design pattern](7) Singleton

    前言 上面的章节中,我们介绍了工厂模式,它是创建型模式的一种.本章我们将会介绍 单例模式 ,它也是创建型模式的一种.单例模式是我们比较常用的一个设计模式,也是最简单的一种设计模式. 单例模式 介绍:确 ...

  7. wannafly 练习赛11 E 求最值(平面最近点对)

    链接:https://www.nowcoder.com/acm/contest/59/E 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他语言65536K 64bit ...

  8. 用命令行编译运行java文件的乱码问题

    之前在写的时候没有遇到过这个问题,用惯了eclipse之后突然用Notepad++就出现乱码了 我在编写的时候 指定Noepad++的编码是 UTF-8编码,然后进入命令行,编译的时候就出现了乱码 然 ...

  9. 题目1.A乘以B

    看我没骗你吧 —— 这是一道你可以在10秒内完成的题:给定两个绝对值不超过100的整数A和B,输出A乘以B的值. 1实验代码 #include<stdio.h>int main(void) ...

  10. 测开之路一百二十七:flask之构造response对象

    可以使用flask.make_response构造自定义响应信息 构造一个响应信息为文本,状态码为404 响应 响应数据为json,状态码为200 返回html # coding:utf-8from ...