目录
thinkphp多表查询
首页 php教程 php手册 thinkphp多表查询

thinkphp多表查询

Jun 13, 2016 am 09:28 AM

thinkphp多表查询

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

 

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

 

有以下三张表,分表为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方法默认查询的是所有字段的值

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1672
14
CakePHP 教程
1428
52
Laravel 教程
1332
25
PHP教程
1276
29
C# 教程
1256
24