00001 <?php 00002 /** 00003 * Magento 00004 * 00005 * NOTICE OF LICENSE 00006 * 00007 * This source file is subject to the Open Software License (OSL 3.0) 00008 * that is bundled with this package in the file LICENSE.txt. 00009 * It is also available through the world-wide-web at this URL: 00010 * http://opensource.org/licenses/osl-3.0.php 00011 * If you did not receive a copy of the license and are unable to 00012 * obtain it through the world-wide-web, please send an email 00013 * to license@magentocommerce.com so we can send you a copy immediately. 00014 * 00015 * DISCLAIMER 00016 * 00017 * Do not edit or add to this file if you wish to upgrade Magento to newer 00018 * versions in the future. If you wish to customize Magento for your 00019 * needs please refer to http://www.magentocommerce.com for more information. 00020 * 00021 * @category Mage 00022 * @package Mage_Catalog 00023 * @copyright Copyright (c) 2008 Irubin Consulting Inc. DBA Varien (http://www.varien.com) 00024 * @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0) 00025 */ 00026 00027 /* @var $this Mage_Catalog_Model_Resource_Eav_Mysql4_Setup */ 00028 $this->startSetup(); 00029 00030 $this->getConnection()->addColumn($this->getTable('catalog_category_entity'), 'children_count', 'INT NOT NULL'); 00031 00032 $sql = "SELECT * FROM `{$this->getTable('catalog_category_entity')}`"; 00033 $data = $this->getConnection()->fetchAll($sql); 00034 00035 foreach ($data as $row) { 00036 $sql = "SELECT COUNT(*) FROM `{$this->getTable('catalog_category_entity')}` WHERE `path` REGEXP '^{$row['path']}\/([0-9]+)$'"; 00037 $count = (int) $this->getConnection()->fetchOne($sql); 00038 00039 $this->run("UPDATE `{$this->getTable('catalog_category_entity')}` 00040 SET `children_count` = $count 00041 WHERE `entity_id` = {$row['entity_id']}"); 00042 } 00043 00044 $this->endSetup();