我正在处理业务目录之类的事情,并且需要在类别列表中显示类别的递归父级。
我为此使用以下功能:
public function get_recursive_parents($category_id){
$categories = array();
$res = $this->db->from('categories')->where('cat_id',$category_id)->get()->row_array();
$cat_id = $res['parent_id'];
$categories[] = $res;
while($cat_id){
$res = $this->db->from('categories')->where('cat_id',$cat_id)->get()->row_array();
$categories[] = $res;
$cat_id = $res['parent_id'];
}
return $categories;
}
我正在使用此功能,因为它在管理站点上并且在管理站点上有点慢也可以,并且管理员将只有一个,所以我可以给它更多内存。但我认为一次调用的限制内存超过 300M 是太多了,仍然得到这个:
Fatal error: Allowed memory size of 367001600 bytes exhausted (tried to allocate 72 bytes) in /var/www/usmanproject/salesfinder/system/database/DB_active_rec.php on line 2007
那么有没有办法让我可以优化上述功能?或者我需要做某种特定类型的索引或算法优化,或任何其他可能的方式?或者我只是停止显示类别的所有父母和超级父母(即客户要求查看层次结构)?或者需要增加内存,因为我已经在一个目录上工作了,而且在管理站点上也很慢,所以我猜他们只是在使用更多的内存?
任何建议将被认真考虑。
这是那个表模式,它有 parent_id 所以它作为递归关系工作。
CREATE TABLE IF NOT EXISTS `categories` (
`cat_id` int(11) NOT NULL AUTO_INCREMENT,
`cat_name` varchar(255) DEFAULT NULL,
`cat_title` varchar(255) DEFAULT NULL,
`cat_desc` varchar(255) DEFAULT NULL,
`cat_text` text,
`parent_id` int(11) NOT NULL,
`cat_img` varchar(255) DEFAULT NULL,
`sort_id` int(11) NOT NULL DEFAULT '1',
`last_level` tinyint(4) NOT NULL,
PRIMARY KEY (`cat_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=221 ;