2

我正在使用一个不可更改的遗留数据库模式,其中对象的每个实例在数据库中都有自己的表以及相关的记录。useTable每次实例化模型时,我都需要更改模型,但要保留 Cake 的良好缓存等。

假设我有很多 pad 对象,每个都有几个 note 对象(Note belongsTo Pad, Pad hasMany Note)。每个 pad 在 pads 表中都有一条记录,但是每个音符在数据库中都有自己的表(比如标题为“pad_{id}”)。这个模式是固定的,我必须使用它。

现在我不需要做任何保存,所以我在模型的 before find 中执行此操作以支持阅读:

function beforeFind($query_data) {
    if(empty($query_data['pad_id'])) {
        return false;
    } else {
        $this->useTable = $query_data['pad_id'];
        parent::__construct();
        return $query_data;
    }

}

这会更改数据库中使用的模型表,并且在Core::debug > 0. 但是,当它为零时,我认为 CakePHP 会缓存模型代码并且不会正确更改表。无论如何,当我访问 /pads/view/{pad_id} 或任何动态更改此表的操作时,我都会收到 404 错误。我无法弄清楚确切的错误是什么,因为当我打开调试时它工作正常。因此,有关调试此问题的任何指示也会有所帮助。

谢谢!

4

2 回答 2

9

您应该能够使用setSource()来更改模型正在使用的表。 $this->setSource('pad_x')将表设置为“pad_x”并重置模型的模式。API 参考

于 2009-10-08T13:41:12.840 回答
1

var $persistModel = false; 在您的控制器或 AppController 中尝试。

见:http ://www.pseudocoder.com/archives/2009/03/17/8-ways-to-speed-up-cakephp-apps/

于 2009-10-01T20:05:48.890 回答