0

CakePHP が初めてで、初めての参加を試みています。users と呼ばれる 1 つのテーブルと、projects と呼ばれる 1 つのテーブルがあります。1 人のユーザーが複数のプロジェクトを持つことができるため、プロジェクトには user_id 列があります。

これがprojects_controllerでの私のアクションです:

function index() {

    $this->set('projects', $this->Project->find('all', array('joins' => array(
        array(
            'table' => 'users',
            'alias' => 'UsersTable',
            'type' => 'inner',
            'foreginKey' => false,
            'conditions' => array('UsersTable.id = Project.user_id')
        )
    ))));




}

SQL ダンプは次のとおりです。

SELECT `Project`.`id`, `Project`.`title`, `Project`.`created`, `Project`.`website`, `Project`.`language_id`, `Project`.`user_id` FROM `projects` AS `Project` inner JOIN users AS `UsersTable` ON (`UsersTable`.`id` = `Project`.`user_id`) WHERE 1 = 1

ご覧のとおり、users テーブルから何も選択していないことを除けば、すべて問題ないように見えますが、テーブルに参加しています。

そして、ここに私の見解があります:

<table>
<tr>
    <th>Name</th>
    <th>User</th>
</tr>



<?php foreach ($projects as $project): ?>
<tr>
    <td>
        <?php echo $html->link($project['Project']['title'], array('controller' => 'projects', 'action' => 'view', $project['Project']['id'])); ?>
    </td>   
    <td>
        <?php echo $html->link($project['Project']['username'], array('controller' => 'users', 'action' => 'view', $project['Project']['user_id'])); ?>
    </td>   
</tr>
<?php endforeach; ?>

私はどこかを台無しにしましたか?ビューは、それを所有するユーザーとともにすべてのプロジェクトを一覧表示しようとします。

どうもありがとう、

ジョンジー

4

1 に答える 1

1

プロジェクトモデルを次のように編集することで、私が達成したいことがわかりました。

var $belongsTo = array(
    'User' => array(
        'className'    => 'User',
        'foreignKey'    => 'user_id'
    )
); 

これでうまくいきました!

于 2010-08-21T16:06:46.807 に答える