Hai ý tưởng:
Tìm nạp động trường được tổng hợp mỗi khi bạn cần bằng cách sử dụng Hành vi có thể điều chỉnh , như (ngoài ý muốn của tôi):
$this->Tree->find('all', array(
...
'contain' => array(
'Leaf' => array(
'fields' => array('SUM(Leaf.value)'),
'group' => array('Leaf.tree_id')
)
)
);
Hoặc tạo một cột mới trong mô hình Cây như leaf_values
và cập nhật nó mỗi khi bạn thay đổi thứ gì đó trong mô hình Leaf:
// Leaf model
function afterSave() {
$sum = /* calculate sum */;
$this->Tree->updateAll(
array('Tree.leaf_values' => $sum),
array('Tree.id' => $this->data['Leaf']['tree_id'])
);
}
function afterDelete() {
// same for afterDelete
}