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
PHP合并数组+与array_merge的区别分析
Aug 01 PHP
PHP可逆加密/解密函数分享
Sep 25 PHP
PHP fopen()和 file_get_contents()应用与差异介绍
Mar 19 PHP
laravel 5 实现模板主题功能
Mar 02 PHP
php关联数组快速排序的方法
Apr 17 PHP
php表单加入Token防止重复提交的方法分析
Oct 10 PHP
阿里云Win2016安装Apache和PHP环境图文教程
Mar 11 PHP
Laravel框架路由管理简单示例
May 07 PHP
PHP实现数组根据某个字段进行水平合并,横向合并案例分析
Oct 08 PHP
解决laravel中日志权限莫名变成了root的问题
Oct 17 PHP
laravel框架模型中非静态方法也能静态调用的原理分析
Nov 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
php中并发读写文件冲突的解决方案
2013/10/25 PHP
PHP实现加强版加密解密类实例
2015/07/29 PHP
学习php设计模式 php实现适配器模式
2015/12/07 PHP
PHP高并发和大流量解决方案整理
2019/12/24 PHP
php post换行的方法
2020/02/03 PHP
用Javascript 获取页面元素的位置的代码
2009/09/25 Javascript
jQuery旋转插件—rotate支持(ie/Firefox/SafariOpera/Chrome)
2013/01/16 Javascript
百度地图api应用标注地理位置信息(js版)
2013/02/01 Javascript
JS增加行复制行删除行的实现代码
2013/11/09 Javascript
Js可拖拽放大的层拖动特效实现方法
2015/02/25 Javascript
jQuery实现瀑布流布局详解(PC和移动端)
2020/09/01 Javascript
使用struts2+Ajax+jquery验证用户名是否已被注册
2016/03/22 Javascript
浅谈js函数的多种定义方法与区别
2016/11/29 Javascript
重新理解JavaScript的六种继承方式
2017/03/24 Javascript
详解AngularJS用Interceptors来统一处理HTTP请求和响应
2017/06/08 Javascript
使用JS实现图片轮播的实例(前后首尾相接)
2017/09/21 Javascript
Three.js利用性能插件stats实现性能监听的方法
2017/09/25 Javascript
vue实现城市列表选择功能
2018/07/16 Javascript
angular5 子组件监听父组件传入值的变化方法
2018/09/30 Javascript
Vue data的数据响应式到底是如何实现的
2020/02/11 Javascript
python命令行参数解析OptionParser类用法实例
2014/10/09 Python
pytorch: tensor类型的构建与相互转换实例
2018/07/26 Python
python系统指定文件的查找只输出目录下所有文件及文件夹
2020/01/19 Python
python 实现压缩和解压缩的示例
2020/09/22 Python
CSS3实现跳动的动画效果
2016/09/12 HTML / CSS
如何用css3实现switch组件开关的方法
2018/02/09 HTML / CSS
解决Firefox下不支持outerHTML问题代码分享
2014/06/04 HTML / CSS
使用layui实现左侧菜单栏及动态操作tab项的方法
2020/11/10 HTML / CSS
系统管理员的职责包括那些?管理的对象是什么?
2016/09/20 面试题
四群教育工作实施方案
2014/03/26 职场文书
公司授权委托书
2014/04/04 职场文书
优秀班组长事迹
2014/05/31 职场文书
反四风个人对照检查材料思想汇报
2014/09/25 职场文书
学生检讨书如何写
2014/10/30 职场文书
2015年学校安全管理工作总结
2015/05/11 职场文书
党章学习心得体会2016
2016/01/14 职场文书