thinkphp学习笔记之多表查询


Posted in PHP onJuly 28, 2014

在操作过程中,两表查询都没有问题,但是三表查询就开始出现问题

有以下三张表,分表为pl表(uid,content),user表(id,username),lyb表(uid,title)

多表查询操作有以下几种方法:

㈠视图模型(推荐)

定义视图模型,只需要继承Think\Model\ViewModel,然后设置viewFields属性即可

public $viewFields = array(
    'pl'    =>array('uid','rid','content'),
    'user'    =>array('id','username','_on'=>'pl.uid=user.id'),
    'lyb'    =>array('uid'=>'lid','content'=>'lyb_content','title','_on'=>'pl.uid=lyb.uid'), //如果表中有字段重名,可以通过=>设置别名,'uid'=>'lid'
    );

视图查询:

视图查询和不同模型的查询一样,没有什么区别。

$Model = D("pl") ->field('uid,title,username,lyb_content')->select();  //pl为数据库名

如果发现查询的结果存在重复数据,还可以使用group方法来处理。

㈡join

JOIN方法也是连贯操作方法之一,用于根据两个或多个表中的列之间的关系,从这些表中查询数据。

join通常有下面几种类型,不同类型的join操作会影响返回的数据结果。

INNER JOIN : 如果表中有至少一个匹配,则返回行,等同于 JOIN
LEFT JOIN : 即使右表中没有匹配,也从左表返回所有的行
RIGHT JOIN : 即使左表中没有匹配,也从右表返回所有的行
FULL JOIN : 只要其中一个表中存在匹配,就返回行
join方法可以支持以上四种类型:

同样是对以上三张表进行操作

$Model = D("pl")
->join('lyb on pl.uid = lyb.uid')
->join('user on pl.uid = user.id') 
->field('user.username,lyb.title,pl.content')
->select();

㈢table

table方法也属于模型类的连贯操作方法之一,主要用于指定操作的数据表。

用法

一般情况下,操作模型的时候系统能够自动识别当前对应的数据表,所以,使用table方法的情况通常是为了:

切换操作的数据表;
对多表进行操作;                                                                                                                                                                                       

$Model = D("pl")
->field('pl.content,user.username,lyb.title')
->table('pl,lyb,user')
->limit(10)
->select();

注:table方法默认查询的是所有字段的值

PHP 相关文章推荐
拼音码表的生成
Oct 09 PHP
CakePHP去除默认显示的标题及图标的方法
Oct 22 PHP
PHP开发过程中常用函数收藏
Dec 14 PHP
DedeCMS 核心类TypeLink.class.php摘要笔记
Apr 07 PHP
PHP文件注释标记及规范小结
Apr 01 PHP
浅析PHP的静态成员函数效率更高的原因
Jun 13 PHP
ThinkPHP3.2.2的插件控制器功能
Mar 05 PHP
php检测url是否存在的方法
Apr 14 PHP
PHP SPL 被遗落的宝石【SPL应用浅析】
Apr 20 PHP
Thinkphp整合阿里云OSS图片上传实例代码
Apr 28 PHP
PHP字符串中抽取子串操作实例分析
Jun 22 PHP
基于laravel缓冲cache的用法详解
Oct 23 PHP
CMS中PHP判断系统是否已经安装的方法示例
Jul 26 #PHP
PHP中file_exists函数不支持中文名的解决方法
Jul 26 #PHP
一个简洁实用的PHP缓存类完整实例
Jul 26 #PHP
PHP实现多图片上传类实例
Jul 26 #PHP
PHP判断文章里是否有图片的简单方法
Jul 26 #PHP
php中创建和调用webservice接口示例
Jul 25 #PHP
Codeigniter中mkdir创建目录遇到权限问题和解决方法
Jul 25 #PHP
You might like
在CentOS系统上从零开始搭建WordPress博客的全流程记录
2016/04/21 PHP
PHP7如何开启Opcode打造强悍性能详解
2018/05/11 PHP
PHP设计模式之建造者模式定义与用法简单示例
2018/08/13 PHP
比较全的JS checkbox全选、取消全选、删除功能代码
2008/12/19 Javascript
jquery ajax 同步异步的执行示例代码
2010/06/23 Javascript
silverlight线程与基于事件驱动javascript引擎(实现轨迹回放功能)
2011/08/09 Javascript
Javascript对象中关于setTimeout和setInterval的this介绍
2012/07/21 Javascript
利用JS解决ie6不支持max-width,max-height问题的方法
2014/01/02 Javascript
jQuery实现的漂亮表单效果代码
2015/08/18 Javascript
jquery实现的点击翻书效果代码
2015/11/04 Javascript
js 判断数据类型的几种方法
2017/01/13 Javascript
Angular2中如何使用ngx-translate进行国际化
2017/05/21 Javascript
JS原生带小白点轮播图实例讲解
2017/07/22 Javascript
浅谈Angular4中常用管道
2017/09/27 Javascript
Angular中点击li标签实现更改颜色的核心代码
2017/12/08 Javascript
JavaScript 高性能数组去重的方法
2018/09/20 Javascript
Vue发布项目实例讲解
2019/07/17 Javascript
[06:44]2014DOTA2国际邀请赛-钥匙体育馆开战 开幕式振奋人心
2014/07/19 DOTA
tensorflow 获取变量&打印权值的实例讲解
2018/06/14 Python
python爬取哈尔滨天气信息
2018/07/14 Python
python迭代器常见用法实例分析
2019/11/22 Python
Python下利用BeautifulSoup解析HTML的实现
2020/01/17 Python
Python多线程操作之互斥锁、递归锁、信号量、事件实例详解
2020/03/24 Python
HTML5新特性之语义化标签
2017/10/31 HTML / CSS
阿迪达斯西班牙官方网站:adidas西班牙
2016/07/21 全球购物
Bibloo奥地利:购买女装、男装、童装、鞋和配件
2018/10/18 全球购物
全球性的女装店:storets
2019/06/12 全球购物
你对IPv6了解程度
2016/02/09 面试题
拓展培训心得体会
2014/01/04 职场文书
模范教师材料大全
2014/12/16 职场文书
村官个人总结范文
2015/03/03 职场文书
出纳2015年度工作总结范文
2015/10/14 职场文书
导游词之江苏同里古镇
2019/11/18 职场文书
PyTorch 如何检查模型梯度是否可导
2021/06/05 Python
navicat 连接Ubuntu虚拟机的mysql的操作方法
2022/04/02 MySQL
python和Appium的移动端多设备自动化测试框架
2022/04/26 Python