CakePHP-正确的方式做hasMany-through


CakePHP - Correct way to do hasMany through

我有三种型号的

分类:

 class Category extends AppModel {
     public $belongsTo = array(
        'Parent' => array(
            'className' => 'Category',
            'foreignKey' => 'parent_id'
        ),
     );
     public $hasMany = array(
         'Children' => array(
            'className' => 'Category',
            'foreignKey' => 'parent_id'
         ), 
        'UserCategoryMeta'
     );
}

用户:

class User extends AppModel {
    public $hasMany = array(
        'UserCategoryMeta' => array(
            'className' => 'UserCategoryMeta',
            'foreignKey' => 'user_id',
        ),
    );
}

用户类别Meta:

class UserCategoryMeta extends AppModel
{
    public $belongsTo = array(
        'User', 'Category'
    );
}

我需要做的是让每个用户都能够选择许多类别,对于这些关联中的每一个,我需要用户设置搜索项,这只是数据库中的一个字段。

因此UserCategoryMeta表如下所示:

id  |  user_id  | category_id  |  search_terms

我找到了一种可行的方法,但似乎很难。

在用户控制器中,我有:

$Categories = $this->User->Category->find('list');

然后在添加视图中,我有复选框:

echo $this->Form->input('Category.Category',array(
    'type' => 'select', 
    'multiple' =>'checkbox',
    'options' => $Categories,
));

然后,我可以让每个复选框旁边都有一个搜索词输入的唯一方法是在添加视图中这样做:

foreach ($Categories as $key => $category){
    echo '<input type="text" id="Category'.$key.'SearchTerms" name="data[Category][search_terms]['.$key.']"><br/>';
}

这产生了我想要的东西,但很明显,因为我只是在提交表格时创建随机输入,所以它被打了个黑洞。我已经设法通过了,但我知道我做得不对,希望有人能帮助我做得对。

此外,一旦我在控制器中有了这个数据数组,我就不知道如何正确地将其保存到数据库中。

提前感谢您的帮助!

只需做您正在做的事情,但在重复中,使用$this->Form->输入,而不是手动编写HTML。