首页 > 编程 > PHP > 正文

thinkphp学习笔记之多表查询

2020-03-22 17:52:26
字体:
来源:转载
供稿:网友
在操作过程中,两表查询都没有问题,但是三表查询就开始出现问题有以下三张表,分表为pl表(uid,content),user表(id,username),lyb表(uid,title)多表查询操作有以下几种方法:㈠视图模型(推荐)定义视图模型,只需要继承Think/Model/ViewModel,然后设置viewFields属性即可html' target='_blank'>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方法来处理。㈡joinJOIN方法也是连贯操作方法之一,用于根据两个或多个表中的列之间的关系,从这些表中查询数据。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();㈢tabletable方法也属于模型类的连贯操作方法之一,主要用于指定操作的数据表。用法一般情况下,操作模型的时候系统能够自动识别当前对应的数据表,所以,使用table方法的情况通常是为了:切换操作的数据表;
对多表进行操作;$Model = D("pl") - field('pl.content,user.username,lyb.title') - table('pl,lyb,user') - limit(10) - select();注:table方法默认查询的是所有字段的值PHP教程

郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表