thinkphp多表查询
在学习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多表查询
关键词:
上一篇:高性能Javascript--脚本的无阻塞加载策略澳门娱乐
下一篇:没有了