CakePHP yeni ve benim ilk katılmaya çalışıyorum. Kullanıcıların ve tek denilen projeler olarak adlandırılan bir tablo var. bir kullanıcı birçok proje var, bu yüzden projeler User_id sütun vardır.
İşte projects_controller benim eylemdir:
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')
)
))));
}
Burada SQL dökümü:
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
Gördüğünüz gibi her şey onun kullanıcıların tablosundan şey seçerek değil dışında iyi görünüyor ama bunu katılıyor.
Ve burada benim görünümüdür:
<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; ?>
Ben bir yere kadar berbat mı? görünüm sahibi olan kullanıcı ile birlikte tüm projeleri listelemek için çalışır.
Çok teşekkür ederim,
Jonesy