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生成静态页面详解
Nov 19 PHP
PHP通过header实现文本文件下载的代码
Aug 08 PHP
用PHP的超级变量$_GET获取HTML表单(Form) 数据
May 07 PHP
php使用Smarty的相关注意事项及访问变量的几种方式
Dec 08 PHP
PHP中上传多个文件的表单设计例子
Nov 19 PHP
PHP 微信支付类 demo
Nov 30 PHP
Yii中CArrayDataProvider和CActiveDataProvider区别实例分析
Mar 02 PHP
详解PHP的Yii框架中组件行为的属性注入和方法注入
Mar 18 PHP
PHP sleep()函数, usleep()函数
Aug 25 PHP
php mysql 封装类实例代码
Sep 18 PHP
PHP中register_shutdown_function函数的基础介绍与用法详解
Nov 28 PHP
laravel model 两表联查示例
Oct 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 服务器调试 Zend Debugger 的安装教程
2009/09/25 PHP
解析PHP提交后跳转
2013/06/23 PHP
使用PHP会话(Session)实现用户登陆功能
2013/06/29 PHP
php实现查看邮件是否已被阅读的方法
2013/12/03 PHP
CI操作cookie的方法分析(基于helper类库)
2016/03/28 PHP
基于PHP实现短信验证码接口(容联运通讯)
2016/09/06 PHP
JavaScript 以对象为索引的关联数组
2010/05/19 Javascript
使用js正则控制input标签只允许输入的值
2013/07/29 Javascript
Js控制弹窗实现在任意分辨率下居中显示
2013/08/01 Javascript
node.js中的http.request.end方法使用说明
2014/12/10 Javascript
JavaScript计算器网页版实现代码分享
2016/07/15 Javascript
js 定义对象数组(结合)多维数组方法
2016/07/27 Javascript
将Sublime Text 3 添加到右键中的简单方法
2017/12/12 Javascript
jQuery动态添加元素无法触发绑定事件的解决方法分析
2018/01/02 jQuery
Vue中android4.4不兼容问题的解决方法
2018/09/04 Javascript
jQuery实现鼠标移入显示蒙版效果
2020/01/11 jQuery
使用webpack和rollup打包组件库的方法
2021/02/25 Javascript
python使用nntp读取新闻组内容的方法
2015/05/08 Python
python访问mysql数据库的实现方法(2则示例)
2016/01/06 Python
Python自动化测试ConfigParser模块读写配置文件
2016/08/15 Python
给你选择Python语言实现机器学习算法的三大理由
2017/11/15 Python
Python中Threading用法详解
2017/12/27 Python
Django代码性能优化与Pycharm Profile使用详解
2018/08/26 Python
浅谈python下tiff图像的读取和保存方法
2018/12/04 Python
Python 加密与解密小结
2018/12/06 Python
python实现读取excel文件中所有sheet操作示例
2019/08/09 Python
解决python中的幂函数、指数函数问题
2019/11/25 Python
Pytest框架之fixture的详细使用教程
2020/04/07 Python
python 读取.nii格式图像实例
2020/07/01 Python
详解CSS3实现响应式手风琴效果
2020/06/10 HTML / CSS
电大自我鉴定范文
2013/10/01 职场文书
岗位职责的含义
2013/11/17 职场文书
四风自我剖析材料思想汇报
2014/10/01 职场文书
青年人初次创业的“五不要”
2019/08/23 职场文书
2019年二手房买卖合同范本
2019/10/14 职场文书
详解JAVA的控制语句
2021/11/11 Java/Android