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 相关文章推荐
PHP 文件上传源码分析(RFC1867)
Oct 30 PHP
php zip文件解压类代码
Dec 02 PHP
php 需要掌握的东西 不做浮躁的人
Dec 28 PHP
php中的常用魔术方法总结
Aug 02 PHP
PHP运行SVN命令显示某用户的文件更新记录的代码
Jan 03 PHP
ThinkPHP添加更新标签的方法
Dec 05 PHP
PHP实现的简易版图片相似度比较
Jan 07 PHP
PHP中实现获取IP和地理位置类分享
Feb 10 PHP
功能强大的PHP发邮件类
Aug 29 PHP
PHP操作XML中XPath的应用示例
Jul 04 PHP
laravel框架查询数据集转为数组的两种方法
Oct 10 PHP
laravel 错误处理,接口错误返回json代码
Oct 25 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
具有时效性的php加密解密函数代码
2013/06/19 PHP
php 获取页面中指定内容的实现类
2014/01/23 PHP
php正则替换处理HTML页面的方法
2015/06/17 PHP
Yii 访问 Gii(脚手架)时出现 403 错误
2018/06/06 PHP
createElement动态创建HTML对象脚本代码
2008/11/24 Javascript
jquery JSON的解析方式
2009/07/25 Javascript
JavaScript实现自己的DOM选择器原理及代码
2013/03/04 Javascript
jquery写个checkbox——类似邮箱全选功能
2013/03/19 Javascript
javascript中文本框中输入法切换的问题
2013/12/10 Javascript
js函数名与form表单元素同名冲突的问题
2014/03/07 Javascript
jQuery判断div随滚动条滚动到一定位置后停止
2014/04/02 Javascript
JS给超链接加确认对话框的方法
2015/02/24 Javascript
JS实现的网页背景闪电闪烁效果代码
2015/10/17 Javascript
基于jQuery实现选取月份插件附源码下载
2015/12/28 Javascript
Bootstrap基本组件学习笔记之按钮组(8)
2016/12/07 Javascript
Angular工具方法学习
2016/12/26 Javascript
bootstrap折叠调用collapse()后data-parent不生效的快速解决办法
2017/02/23 Javascript
JavaScript编写一个贪吃蛇游戏
2017/03/09 Javascript
requirejs按需加载angularjs文件实例
2017/06/08 Javascript
Python处理JSON数据并生成条形图
2016/08/05 Python
Python学习笔记之解析json的方法分析
2017/04/21 Python
python实现人脸识别代码
2017/11/08 Python
python opencv设置摄像头分辨率以及各个参数的方法
2018/04/02 Python
Django实现一对多表模型的跨表查询方法
2018/12/18 Python
Python flask框架如何显示图像到web页面
2020/06/03 Python
python 合并多个excel中同名的sheet
2021/01/22 Python
Kathmandu新西兰官网:新西兰户外运动品牌
2019/07/27 全球购物
介绍一下linux的文件系统
2015/10/06 面试题
教学实验楼管理制度
2014/02/01 职场文书
处级干部反四风个人对照检查材料思想汇报
2014/09/27 职场文书
庆七一宣传标语
2014/10/08 职场文书
2014年教研室工作总结
2014/12/06 职场文书
创建文明城市倡议书
2015/04/28 职场文书
2015年幼儿园安全工作总结
2015/05/12 职场文书
python某漫画app逆向
2021/03/31 Python
Python批量将csv文件转化成xml文件的实例
2021/05/10 Python