Cakephp 外键下拉列表在基架中不起作用


cakephp foreign key dropdown not working in scaffold

我的模式很简单-每个用户都有一个 ID 和名称。有些作业属于用户。实际模式-

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;

我的作业控制器看起来像这样-

<?php
class JobsController extends AppController {
    public $scaffold;
    public $name = 'Job';
    public $belongsTo = array(
        'User' => array(
            'className'    => 'User',
            'foreignKey'   => 'user_id'
        )
    );
}

和用户控制器作为-

<?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/中看到

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

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

应用/模型/用户.php中:

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

应用/模型/作业中.php

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