如何在Magento中将quote属性转换为order?

Jan*_*mka 4 attributes magento quote magento-1.6

我花了两天时间在这上面,我觉得我已经尝试了所有的东西,但我仍然一直在撞墙.

我有两个属性(module_job_id,module_channel_id),我很乐意添加到引用和订单中.我设法得到的是引用属性工作正常,我可以看到它们存储在数据库中,可以很好地检索它们.

唯一剩下的就是将报价中的值移动到订单.我究竟做错了什么?

这是我的模块配置文件:

<?xml version="1.0" encoding="UTF-8"?>
<config>

    <modules>
        <Company_Module>
            <version>0.1.9</version>
        </Company_Module>
    </modules>

    <global>
        <fieldsets>
            <sales_convert_quote>
                <module_job_id>
                    <to_order>*</to_order>
                </module_job_id>

                <module_channel_id>
                    <to_order>*</to_order>
                </module_channel_id>
            </sales_convert_quote>
        </fieldsets>

        <resources>
            <company_module>
                <setup>
                    <module>Company_Module</module>
                    <class>Mage_Sales_Model_Mysql4_Setup</class>
                </setup>
                <connection>
                    <use>core_setup</use>
                </connection>
            </company_module>
        </resources>

    </global>
</config>
Run Code Online (Sandbox Code Playgroud)

安装文件sql/company_module/mysql4-install-0.1.0.php:

<?php
    $installer = $this;
    $installer->startSetup();

    $installer->getConnection()->addColumn($installer->getTable('sales/quote'), 'module_job_id',
        'VARCHAR(255) NULL DEFAULT NULL');
    $installer->getConnection()->addColumn($installer->getTable('sales/quote'), 'module_channel_id',
        'VARCHAR(255) NULL DEFAULT NULL');

    $installer->getConnection()->addColumn($installer->getTable('sales/order'), 'module_job_id',
        'VARCHAR(255) NULL DEFAULT NULL');
    $installer->getConnection()->addColumn($installer->getTable('sales/order'), 'module_channel_id',
        'VARCHAR(255) NULL DEFAULT NULL');

    $installer->addAttribute('order', 'module_job_id', array('type' => 'varchar'));
    $installer->addAttribute('quote', 'module_job_id', array('type' => 'varchar'));

    $installer->addAttribute('order', 'module_channel_id', array('type' => 'varchar'));
    $installer->addAttribute('quote', 'module_channel_id', array('type' => 'varchar'));

    $installer->endSetup();
Run Code Online (Sandbox Code Playgroud)

我已经在安装文件中尝试了addAttribute和addColumns的所有可能组合.结果是我在sales_flat_quote和sales_flat_order中都将这两个属性作为列.但是,eav_attribute中没有任何属性.我不确定这是否可以.

我尝试的另一件事是在sales_convert_quote_to_order观察器中显式设置order属性值.这不起作用:

public function salesConvertQuoteToOrder($observer)
{
    $order = $observer->getEvent()->getOrder();

    $order->setModuleJobId('123');
    $order->setModuleChannelId('456');
}
Run Code Online (Sandbox Code Playgroud)

我不知道它是否重要,但这些是我系统上的实体类型(只有订单,没有报价......):

mysql> SELECT entity_type_id, entity_type_code FROM eav_entity_type;
+----------------+------------------+
| entity_type_id | entity_type_code |
+----------------+------------------+
|              3 | catalog_category |
|              4 | catalog_product  |
|              7 | creditmemo       |
|              1 | customer         |
|              2 | customer_address |
|              6 | invoice          |
|              5 | order            |
|              8 | shipment         |
+----------------+------------------+
Run Code Online (Sandbox Code Playgroud)

此外,eav_entity为空.我希望也没关系.

mysql> select * from eav_entity;
Empty set (0.00 sec)
Run Code Online (Sandbox Code Playgroud)

这是在Magento 1.6.2.0上.谢谢堆!

小智 6

在Magento 1.6.2.0上,订单保存在sales_flat_order上,报价保存在sales_flat_quote上.他们不再使用eav结构AFAIK所以我会说它没关系.您应该查看类Mage_Sales_Model_Convert_Quote并添加调试代码:

public function toOrder(Mage_Sales_Model_Quote $quote, $order=null)
{
    if (!($order instanceof Mage_Sales_Model_Order)) {
        $order = Mage::getModel('sales/order');
    }
    /* @var $order Mage_Sales_Model_Order */

    $order->setIncrementId($quote->getReservedOrderId())
        ->setStoreId($quote->getStoreId())
        ->setQuoteId($quote->getId())
        ->setQuote($quote)
        ->setCustomer($quote->getCustomer());

    Mage::helper('core')->copyFieldset('sales_convert_quote', 'to_order', $quote, $order);

    Mage::dispatchEvent('sales_convert_quote_to_order', array('order'=>$order, 'quote'=>$quote));

    //I add my debug code here using Mage::log, you can debug using your own method
    Mage::log($order->getData());

    return $order;
}
Run Code Online (Sandbox Code Playgroud)

要查看是否在那里设置了module_job_id和module_channel_id.