文档章节

Thinkphp连多表查询,关联2个或多个字段

botkenni
 botkenni
发布于 2017/02/03 11:04
字数 326
阅读 127
收藏 0

tp连表查询的问题:a表的user_id关联b表的id,a表的race_id关联c表的race_id,a表的race_id和user_id关联d表的race_id和user_id。4表关联,a表和d表还是关联2个字段。
tp作为国内最优秀的php框架,提供了一种简单的join来关联表。下面是示例代码

$where = array(
          'a.id'=>1,
          'b.id'=>1,
);
$result  = $this ->join('LEFT JOIN  b ON a.user_id = b.id')
                        ->join('LEFT JOIN  c ON a.race_id = c.race_id')
                        ->join('LEFT JOIN  d a.race_id = d.race_id AND a.user_id = d.user_id')
                        ->where($where)
                        ->select();

当然,这只是一个小例子,where条件中的a.id代表a表中的id字段,b.id同理。 LEFT JOIN就是php中连表查询中常用的,join()可以一直加下去(只要表名对应的字段存在,即a.user_id = b.id,a表中必须有user_id,b表中必须有id,条件才能成立)

大家知道,连表有时候会有重复字段,我的解决方法是使用thinkphp中的field()。例如:

    $result  = $this ->join('LEFT JOIN  b ON a.user_id = b.id')
                        ->join('LEFT JOIN  c ON a.race_id = c.race_id')
                        ->join('LEFT JOIN  d a.race_id = d.race_id AND a.user_id = d.user_id')
                        ->where($where)
                        -> field('a.name as a_name , b.*,c.&,d.*')
                        ->select();

a.name as a_name意思就是把a表中的name字段换成a_name去显示出来。b.*代表的是取b表中的全部数据。

 

© 著作权归作者所有

botkenni
粉丝 20
博文 429
码字总数 444521
作品 0
西城
程序员
私信 提问
ThinkPHP 查询数据 select(findAll) 方法

ThinkPHP 查询数据 ThinkPHP 查询数据主要提供以下几类查询: select:普通查询,同 findAll() 方法 find:取得符合查询条件的一条记录 getBy动态查询:根据某个字段取得符合查询条件的一条记...

WangEven
2012/05/10
168
0
ThinkPHP3.0新特性: 快捷查询

新版增加了快捷查询方式,可以进一步简化查询条件的写法,例如: 一、实现不同字段相同的查询条件 $User = M("User"); // 实例化User对象 $map['name|title'] = 'thinkphp'; // 把查询条件传......

岭南六少
2012/02/27
437
0
ThinkPHP V5.0.10 版本发布,Bug 修复和改进

ThinkPHP V5.0.10 已发布,V5.0.10版本主要为BUG修正和改进,并且包含一个安全更新,可以从5.0.9无缝升级,推荐更新,主要改进如下: 主要更新 数据库和模型的多处改进 添加新的行为监听 路由...

流年
2017/07/05
1K
13
网站安全检测 网站漏洞修复 对thinkphp通杀漏洞利用与修复建议

thinkphp在国内来说,很多站长以及平台都在使用这套开源的系统来建站,为什么会这么深受大家的喜欢,第一开源,便捷,高效,生成静态化html,第二框架性的易于开发php架构,很多第三方的插件...

网站安全
2018/09/05
151
0
ThinkPHP的CURD操作

CURD:create(创建)、update(更新)、read(读取)、delete(删除) 1.数据对象创建(create): a.TP提供了create方法迅速的创建数据对象,可一自动的根据表单数据创建对象,支持数组,对象,甚至可...

笨小熊
2015/06/29
265
0

没有更多内容

加载失败,请刷新页面

加载更多

006-Sigle-基于blockstack去中心化博客

本篇文章主要讲解有关基于Blockstack的Sigle是一个去中心化的博客项目; 官网地址:https://www.sigle.io/ Github地址:https://github.com/pradel/sigle 页面展示: 介绍: A beautiful de...

Riverzhou
15分钟前
8
0
驰骋工作流引擎开发平台属性功能的隐藏显示介绍

关键字: 工作流程管理系统 工作流引擎 asp.net工作流引擎 java工作流引擎. 表单引擎 工作流功能说明 工作流设计 工作流快速开发平台 业务流程管理 bpm工作流系统 java工作流主流框架 自定义...

孟娟
16分钟前
7
0
MyBatis binding 模块分析

MyBatis binding 模块分析 binding功能代码所在包 org.apache.ibatis.binding binding模块作用 封装ibatis编程模型 ibatis编程模型中,SqlSession作为sql执行的入口,实用方法为sqlSession.se...

红妍落日
18分钟前
4
0
网易互娱的数据库选型和 TiDB 应用实践

作者介绍:李文杰,网易互娱计费组,高级数据库管理工程师,TiDB User Group Ambassador。 一、业务架构简介 计费组是为网易互娱产品提供统一登录和支付高效解决方案的公共支持部门,对内是互...

TiDB
25分钟前
4
0
Debezium接入Mysql遇到到的Tinyint坑

问题背景: 在Debezium做数据初始化的时候,对于一些tinyint字段的值,出现0,1的值的异常。 经过源码排查,数据在JDBC上面,读取到的数据是Boolean值。 通过排查,原来是MYSQL特有的数据问题...

吐槽的达达仔
33分钟前
8
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部