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编码规范-php coding standard
Mar 16 PHP
在命令行下运行PHP脚本[带参数]的方法
Jan 22 PHP
php抓取页面与代码解析 推荐
Jul 23 PHP
PHP中static关键字原理的学习研究分析
Jul 18 PHP
PHP daddslashes 使用方法介绍
Oct 26 PHP
PHP结合JQueryJcrop实现图片裁切实例详解
Jul 24 PHP
php使用post数组的键值创建同名变量并赋值的方法
Apr 03 PHP
ThinkPHP进程计数类Process用法实例详解
Sep 25 PHP
PHP使用curl模拟post上传及接收文件的方法
Mar 04 PHP
php文件上传 你真的掌握了吗
Nov 28 PHP
php+js实现的无刷新下载文件功能示例
Aug 23 PHP
使用Git实现Laravel项目的自动化部署
Nov 24 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/05/14 PHP
php程序员应具有的7种能力小结
2014/11/27 PHP
Thinkphp3.2.3分页使用实例解析
2016/07/28 PHP
PHP 接入支付宝即时到账功能
2016/09/18 PHP
Laravel模型事件的实现原理详解
2018/03/14 PHP
php操作redis数据库常见方法实例总结
2020/02/20 PHP
jquery 全局AJAX事件使用代码
2010/11/05 Javascript
JS如何将UTC格式时间转本地格式
2013/09/04 Javascript
JS中Date日期函数中的参数使用介绍
2014/01/02 Javascript
node.js中的fs.writeSync方法使用说明
2014/12/15 Javascript
js控制页面的全屏展示和退出全屏显示的方法
2015/03/10 Javascript
JS实现仿QQ效果的三级竖向菜单
2015/09/25 Javascript
javascript创建对象、对象继承的实用方式详解
2016/03/08 Javascript
js检查是否关闭浏览器的方法
2016/08/02 Javascript
基于JS实现回到页面顶部的五种写法(从实现到增强)
2016/09/03 Javascript
JavaScript“尽快失败”的原则实例详解
2016/10/08 Javascript
JavaScript调试之console.log调试的一个小技巧分享
2017/08/07 Javascript
原生javascript实现文件异步上传的实例讲解
2017/10/26 Javascript
VeeValidate在vue项目里表单校验应用案例
2018/05/09 Javascript
详解Vue中使用Echarts的两种方式
2018/07/03 Javascript
JS实现的RC4加密算法示例
2018/08/16 Javascript
浅谈javascript中的prototype和__proto__的理解
2019/04/07 Javascript
JS 封装父页面子页面交互接口的实例代码
2019/06/25 Javascript
vue学习笔记之slot插槽基本用法实例分析
2020/02/01 Javascript
通过vue刷新左侧菜单栏操作
2020/08/06 Javascript
jQuery实现全选按钮
2021/01/01 jQuery
基于Python的XSS测试工具XSStrike使用方法
2017/07/29 Python
python 读取txt中每行数据,并且保存到excel中的实例
2018/04/29 Python
Python 中 function(#) (X)格式 和 (#)在Python3.*中的注意事项
2018/11/30 Python
Python XML转Json之XML2Dict的使用方法
2019/01/15 Python
Python 多个图同时在不同窗口显示的实现方法
2019/07/07 Python
Tornado实现多进程/多线程的HTTP服务详解
2019/07/25 Python
python-web根据元素属性进行定位的方法
2019/12/13 Python
英文版网络工程师求职信
2013/10/28 职场文书
初婚初育证明范本
2014/11/24 职场文书
2016年安全生产先进个人事迹材料
2016/02/29 职场文书