2

我有一个用户模型,用于存储牙科检查系统用户的数据。

通常,将存在三种类型的用户:AdmininistratorLocation ManagerExaminer

似乎有必要在我的应用程序中将这三个角色视为单独的模型(想象一下我如何为每个角色提供不同的视图以及不同的选项等......这是一场噩梦)。

我将如何在每个模型中建立关系。

我的第一个想法是:

//Administrator Model
class Administrator extends User {
    $name = 'Administrator';
    $table = 'User';
    $belongsTo = array(
        'User' => array(
            'className' => 'User',
            'conditions' => array('User.role' => 'administrator'), 
        )
    );
}

然后用户模型将使用 hasMany? 就 CakePHP 约定而言,如何准确地建模呢?

另外,这个模型会扩展 User 模型还是 AppModel?

4

1 回答 1

2

当然,您可以使用相同的表名创建不同的模型。为此,请使用 $useTable 属性(不是 $table)将每个模型与特定表链接:

class Administrator extends AppModel {
    public $useTable = 'User';
}

但我不知道有任何 CakePHP 模型属性可以让您在获取结果时过滤返回的数据……您只能在将模型与另一个模型链接时编写自己的条件,例如:

class SomeOtherModel extends AppModel {
    public $hasMany = array(
        'Administrator' => array(
            'className' => 'Administrator',
            'conditions' => array('Administrator.role' => 'administrator')
        )
    );
}

这不是一个好的解决方案,因为它仅在执行 SomeOtherModel 模型的查询时才有效。

您还可以尝试将 afterFind() 回调应用到您的 Administrator / Examiner / ... 模型,这将删除其他角色的用户而不是需要,但这当然不是一个有效的解决方案。

另一种解决方案是创建不同的数据库视图,其中仅包含选定角色的用户(更多关于视图 -这里)。然后您可以将每个视图指向您的 CakePHP 模型,就像它是一个普通的数据库表一样。但这个解决方案也并不完美。如果您将来必须添加新用户角色或更改表模式,您还必须修改数据库视图。

于 2013-10-04T16:33:45.993 回答