目錄
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

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 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教學
1664
14
CakePHP 教程
1423
52
Laravel 教程
1321
25
PHP教程
1269
29
C# 教程
1249
24