2

有什么方法可以加快这个 Magento 代码的速度吗?目前它正在浏览大约 2k 种产品,运行大约需要 20 分钟。

我猜这个问题与 product->load() 调用有关,但我对 Magento 不够熟悉,无法知道它需要的开销。

谢谢你。

从控制器

Mage::dispatchEvent(
    'category_rule_save',
    array(
        'rule_id'        => $id,
        'attribute_code' => $data['attribute_code'],
        'operator'       => $data['operator'],
        'value'          => $data['value'],
        'category_id'    => $data['category'],
        'store_id'       => $data['store_id']
    )
);

来自 Observer.php

public function onCategoryRuleSave($observe)
{
    $collection =
        Mage::getModel('catalog/product')->getCollection()
            ->addAttributeToSelect($observe['attribute_code']);
    $write = Mage::getSingleton('core/resource')->getConnection('core_write');

    foreach ($collection as $product) {
        $productId = $product->getId();
        $product = $product->load($productId);
        $productAttributeValue = '';
        $productAttributeValue =
            Mage::getModel('catalog/product')->load($productId)
                ->getAttributeText( $observe['attribute_code'] );
        $r = 0;

        if ( is_numeric($observe['value']) ) {
            switch($observe['operator']) {
                case "<":
                    $r = ($productAttributeValue < $observe['value']) ? 1 : 0;
                    break;
                case ">":
                    $r = ($productAttributeValue > $observe['value']) ? 1 : 0;
                    break;
                case "<=":
                    $r = ($productAttributeValue <= $observe['value']) ? 1 : 0;
                    break;
                case ">=":
                    $r = ($productAttributeValue >= $observe['value']) ? 1 : 0;
                    break;
                case "==":
                    $r = ($productAttributeValue == $observe['value']) ? 1 : 0;
                    break;
                case "!=":
                    $r = ($productAttributeValue != $observe['value']) ? 1 : 0;
                    break;
            }
        }
        else {
            switch($observe['operator']) {
                case "==":
                    $r = (
                        strcmp(strtolower($productAttributeValue) , strtolower($observe['value'])) == 0
                    ) ? 1 : 0;
                    break;
                case "!=":
                    $r = (
                        strtolower($productAttributeValue) != strtolower($observe['value'])
                    ) ? 1 : 0;
                    break;
            }
        }

        if ($r==1) {
            $write->query(
                "REPLACE INTO `catalog_category_product` (`category_id`, `product_id`)
                VALUES (" . $observe['category_id'] . "," . $product->getId() . ")"
            );
        }
    }
}
4

2 回答 2

1

尝试将产品加载替换为:

...
foreach ($collection as $product) {
 $productAttributeValue = $product->getAttributeText( $observe['attribute_code'] );
 $r = 0;
...

您正在加载产品对象 2 次。foreach 中的 $product 变量已经是具有您需要使用的属性的已加载产品。考虑到 Magento 的 EAV 数据库结构,加载具有所有属性的 $product 对象的成本很高。

于 2012-06-18T20:10:38.780 回答
0

1.$收藏=
        Mage::getModel('catalog/product')->getCollection()
        ->addAttributeToSelect($observe['attribute_code']);

2.Mage::getModel('catalog/product')->load($productId) ->getAttributeText($observe['attribute_code']);

3.$product = $product->load($productId);

这真的很糟糕:)

$收藏=
        Mage::getModel('catalog/product')->getCollection()
        ->addAttributeToSelect('*');//这个字符串应该加载所有的产品属性
还有一些方法可以添加产品网站、产品商店等。

于 2012-06-19T05:37:21.650 回答