在Cakephp中连接表
我有两张桌子;历史和用户。我需要显示如下数据:在Cakephp中连接表,cakephp,Cakephp,我有两张桌子;历史和用户。我需要显示如下数据: id |用户名|最新创建的帖子|最早创建的帖子 id和username的数据来自users表,最后创建和第一次创建的post数据来自历史记录。我需要查看所有用户,他们最近创建的帖子和他们第一次创建的帖子。请帮助我制作控制器并查看,谢谢尝试下面的内容 <?php $users = $this->User->find('all',array ( 'conditions' => array
id |用户名|最新创建的帖子|最早创建的帖子 id和username的数据来自users表,最后创建和第一次创建的post数据来自历史记录。我需要查看所有用户,他们最近创建的帖子和他们第一次创建的帖子。请帮助我制作控制器并查看,谢谢尝试下面的内容
<?php
$users = $this->User->find('all',array
(
'conditions' => array
(
//conditions goes here
),
'fields' => array
(
'User.id',
'User.username',
'History.Lastest created Post',
'History.First created Post'
)
));
?>
假设“用户”和“历史”表之间的关系是一对一的,并且历史表中有一个“用户id”列,您可能需要在历史模型中指定它们之间的关系,例如:
var $hasOne = array(
'User' => array(
'className' => 'User',
'foreignKey' => 'user_id',
'conditions' => '',
'fields' => '',
'order' => ''
)
);
然后,您需要执行联接
。例如,在您的用户模型中的某个地方,尝试以下操作:
class User extends AppModel {
....
function getAllUsersHistory{
$allHistories = $this->find('all', array(
'joins' => array(
'table' => 'history',
'alias' => 'HistoryJoin'
'type' => 'INNER',
'conditions' => array(
// your conditions, for example: 'History.user_id' => 'User.id'
)
),
'fields' => array(
'User.id',
'User.username',
'History.lastest_created_post',
'History.first_created_post'
)
));
return $allHistories;
}
.....
}
两个表都使用外键相互关联。?关联在模型中定义。