0

我的模式很简单——每个用户都有一个 id 和 name。有属于用户的工作。实际架构-

CREATE TABLE `users` (
   id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,  
  `name` varchar(20) 
) ENGINE=InnoDB DEFAULT CHARSET=latin1;


CREATE TABLE `jobs` (
   id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
  `user_id` INT UNSIGNED ,
  `type` int,  
  FOREIGN KEY (user_id) references  users(id) 
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

我的 JobsController 看起来像这样-

<?php
class JobsController extends AppController {
    public $scaffold;
    public $name = 'Job';

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

}

和 UsersController 作为-

<?php
class UsersController extends AppController {
    public $scaffold;
    public $name = 'User';


    public $hasMany = array(
        'Job' => array(
            'className'     => 'Job',
            'foreignKey'    => 'user_id'
        )
    );
}

问题:

当我访问时,http://hostname/Jobs/add我可以看到用户的下拉列表,但它是空的。我创建了一些可以从中看到的用户http://hostname/Users/

为什么下拉菜单是空的?我可以添加作业,但是当我查看它们时,用户字段显示为空。

4

1 回答 1

4

关联属于模型,而不是控制器。

app/Model/User.php中:

class User extends AppModel {
    public $name = 'User';
    public $hasMany = array('Job');
}

app/Model/Job.php 中

class Job extends AppModel {
    public $name = 'Job';
    public $belongsTo = array('User');
}
于 2012-07-01T22:30:54.463 回答