1

我有两个名为 login 和 userDetail 的表

                        Login

                        login_id
                        uname
                        pswd
                        userdetail_id

                       userdetails

                          userdetail_id
                          name
                          address
                          email

登录表包含 userDetail 表中的 userdetails_id。我想从 Login 表和 userDetail 表中获取所有数据并将其保存到变量中,如果有人知道,请回答我......

4

3 回答 3

4

首先,您的表结构必须如下。

logins Table.
  Id auto_increment
  username
  password
userDetails Table.
  Id auto_increment
  user_id
  name
  address
  etc...

现在每个表的模型都是。

登录

<?php
class Login extends AppModel
{
    var $name = 'User';

    var $hasMany = array
    (
        'UserDetail' => array
        (
            'className' => 'UserDetail',
            'foreignKey' => 'user_id',
            'dependent' => false,
            'conditions' => '',
            'fields' => '',
            'order' => '',
            'limit' => '',
            'offset' => '',
            'exclusive' => '',
            'finderQuery' => '',
            'counterQuery' => ''
        )
}
?>

用户详情

<?php
class UserDetail extends AppModel
{
    var $name = 'UserDetail';

    var $belongsTo = array
    (
        'User' => array
        (
            'className' => 'User',
            'foreignKey' => 'user_id',
            'dependent' => false,
            'conditions' => '',
            'fields' => '',
            'order' => '',
            'limit' => ''
        )
}
?>

最后在您需要获取登录详细信息的控制器中。

$login_detail = $this->Login->find('all');

您将在结果中看到 userDetail 表记录$login_detail。采用

pr($login_detail);
在控制器中查看它的运行情况。

干杯。随意问。

于 2013-01-25T07:46:56.810 回答
2

确保ContainableBehavior已启用。之后,您可以使用以下查询:

$login = $this->Login->find('first', array(
    'contain' => array(
        'Userdetail.userdetail_id'
        'Userdetail.name',
        'Userdetail.address',
        'Userdetail.email'
    ),
    'fields' => array(
        'Login.login_id'
        'Login.uname',
        'Login.pswd'
    ),
    'conditions' => array(
        'Login.login_id' => 1
    )
));
于 2013-01-25T07:45:27.027 回答
-1

此任务的查询将是:

SELECT Login.*, name,address,email
        FROM Login JOIN userdetails
        ON Login.userdetail_id=userdetails.userdetail_id

这个查询的结果可以通过在 cakephp 中循环保存到变量中。

于 2013-01-25T07:31:38.380 回答