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安装为Apache DSO
Oct 09 PHP
用函数读出数据表内容放入二维数组
Oct 09 PHP
PHP性能优化准备篇图解PEAR安装
Dec 05 PHP
thinkphp模板继承实例简述
Nov 26 PHP
ThinkPHP自动完成中使用函数与回调方法实例
Nov 29 PHP
如何使用php实现评委评分器
Jul 31 PHP
在Mac OS上搭建PHP的Yii框架及相关测试环境
Feb 14 PHP
完美解决Thinkphp3.2中插入相同数据的问题
Aug 01 PHP
php简单中奖算法(实例)
Aug 15 PHP
PHP的mysqli_sqlstate()函数讲解
Jan 23 PHP
php精度计算的问题解析
Jun 21 PHP
YII2框架中日志的配置与使用方法实例分析
Mar 18 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上传图片、删除图片实现代码
2010/05/12 PHP
WordPress中使主题支持小工具以及添加插件启用函数
2015/12/22 PHP
PHP中set_include_path()函数相关用法分析
2016/07/18 PHP
让 JavaScript 轻松支持函数重载 (Part 2 - 实现)
2009/08/04 Javascript
js 兼容多浏览器的回车和鼠标焦点事件代码(IE6/7/8,firefox,chrome)
2010/04/14 Javascript
JavaScript中实现sprintf、printf函数
2015/01/27 Javascript
javascript中Math.random()使用详解
2015/04/15 Javascript
jQuery实现文件上传进度条特效
2015/08/12 Javascript
javascript巧用eval函数组装表单输入项为json对象的方法
2015/11/25 Javascript
纯JavaScript代码实现文本比较工具
2016/02/17 Javascript
JS遍历数组和对象的区别及递归遍历对象、数组、属性的方法详解
2016/06/14 Javascript
第一次接触神奇的Bootstrap
2016/10/14 Javascript
BootStrap 获得轮播中的索引和当前活动的焦点对象
2017/05/11 Javascript
[02:38]2018年度DOTA2最佳劣单位选手-完美盛典
2018/12/17 DOTA
用于统计项目中代码总行数的Python脚本分享
2015/04/21 Python
Python备份目录及目录下的全部内容的实现方法
2016/06/12 Python
python基于物品协同过滤算法实现代码
2018/05/31 Python
python安装requests库的实例代码
2019/06/25 Python
python实现逆滤波与维纳滤波示例
2020/02/26 Python
Python读取VOC中的xml目标框实例
2020/03/10 Python
浅析Python 条件控制语句
2020/07/15 Python
英国百安居装饰建材网上超市:B&Q
2016/09/13 全球购物
美国球鞋寄卖网站:Stadium Goods
2018/05/09 全球购物
全球速卖通俄罗斯站:AliExpress俄罗斯
2019/06/17 全球购物
党建目标管理责任书
2014/07/25 职场文书
堂吉诃德读书笔记
2015/06/30 职场文书
护士心得体会范文
2016/01/25 职场文书
护理自荐信
2019/05/14 职场文书
陶瓷类经典广告语集锦
2019/10/25 职场文书
七年级作文之冬景
2019/11/07 职场文书
Nginx访问日志及错误日志参数说明
2021/03/31 Servers
python 如何将两个实数矩阵合并为一个复数矩阵
2021/05/19 Python
MySQL中使用or、in与union all在查询命令下的效率对比
2021/05/26 MySQL
SSM VUE Axios详解
2021/10/05 Vue.js
Android Canvas绘制文字横纵向对齐
2022/06/05 Java/Android
CSS使用SVG实现动态分布的圆环发散路径动画
2022/12/24 HTML / CSS