计算机教程

当前位置:澳门娱乐场网址 > 计算机教程 > thinkphp多表查询

thinkphp多表查询

来源:http://www.ablakeforum.com 作者:澳门娱乐场网址 时间:2019-07-06 17:32

在学习thinkphp 的过程中,需要对多表进行操作,但是在实际过程中,总是遇到各种问题,所以写下这篇博文,作为自己的学习历程

在操作过程中,两表查询都没有问题,但是三表查询就开始出现问题

在操作过程中,两表查询都没有问题,但是三表查询就开始出现问题

有以下三张表,分表为pl表(uid,content),user表(id,username),lyb表(uid,title)

有以下三张表,分表为pl表(uid,content),user表(id,username),lyb表(uid,title)

多表查询操作有以下几种方法:

多表查询操作有以下几种方法:

㈠视图模型(推荐)

㈠视图模型(推荐)

定义视图模型,只需要继承ThinkModelViewModel,然后设置viewFields属性即可

定义视图模型,只需要继承ThinkModelViewModel,然后设置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'
    );   
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为数据库名
 $Model = D("pl") ->field('uid,title,username,lyb_content')->select();   //pl为数据库名

如果发现查询的结果存在重复数据,还可以使用group方法来处理。

如果发现查询的结果存在重复数据,还可以使用group方法来处理。

㈡join

㈡join

JOIN方法也是连贯操作方法之一,用于根据两个或多个表中的列之间的关系,从这些表中查询数据。

本文由澳门娱乐场网址发布于计算机教程,转载请注明出处:thinkphp多表查询

关键词: