Thinkphph 使用RelationModel的三表关联查询机制
2024-10-19 11:48:50
有如下三个表
a表 b表 c表
id bid other id cid other id other
a表的bid关联b表的id,b表的cid关联c表的id
现在需要查询a表的时候顺带把b表和c表的相关信息也查询出来
很多人一开始就想到使用原生的sql语句
select * from a left join b on a.bid=b.id left join c on b.cid=c.id;
但这并不是我想要的!
直接给出使用案例
class AModel extends RelationModel
{
protected $_link = array(
'B'=>array(
'class_name' => 'B',
'mapping_type' => self::BELONGS_TO,
'mapping_name' => 'b',
'foreign_key' => 'bid',//关联id
),
//c表要间接关联b表
'C' => array(
'class_name' => 'C',
'mapping_type' => self::MANY_TO_MANY,
'mapping_name' => 'c',
'mapping_key' => 'bid', // a.bid, a表要关联b表的字段
'foreign_key' => 'id', // c.id
'relation_foreign_key' => 'cid', // b.cid b表要关联c表的字段
'relation_table' => '__B__', //b表,双下划线加大写,会自动转换统一格式的表,如果多个大写例如BFModel,写成__B_F__中间需要用一个下划线隔开
),
);
最新文章
- inline(内联)函数
- 移动端H5页面的最佳终端适配之Flexible
- 【001:转载 ubuntu下: 建立本地SVN服务器】
- 【推荐】JAVA基础◆浅谈3DES加密解密
- 转载:C# HashSet 用法
- 自定义TypeConverter把基础类型转换为复杂类型
- NSBundle、UIImageView和UIButton对比、Xcode文档安装路径、Xcode模拟器安装路径
- 安装oracle后不能连接问题
- ActiveMQ、Stomp、SockJS入门级应用
- solr 学习笔记1
- 欢迎访问我的独立博客 tracefact.net (2019.1.30)
- react-native中的scrollables
- [转][访谈] Olivier Grisel谈scikit-learn和机器学习技术的未来
- oracle 回收表空间的数据文件大小
- vuex的小demo
- ubuntu解压和压缩文件
- Mongo 用户创建及权限管理
- TZOJ 2415 Arctic Network(最小生成树第k小边)
- Network - Tips
- “网红架构师”解决你的Ceph 运维难题