magento订单观察器简单查询


magento order observer simple query

我想添加一个简单的订单观察器,在那里我想要在我的自定义数据库中有几个条目:

订单id、所有产品id和用户来源的推荐人(一些id)、

我在哪里写这个观察者。。我应该用什么观测者,

代码:

config.xml

<?xml version="1.0"?>
<config>
    <global>
        <models>
            <sampleobserversales>
                <class>SampleObserver_Sales_Model</class>
            </sampleobserversales>
        </models>
        <events>
            <sales_order_save_after>
                <observers>
                    <sampleobserver_sales_order_save_after_observer>
                        <type>singleton</type>
                        <class>sampleobserversales/order_save_after_observer</class>
                        <method>activate</method>
                    </sampleobserver_sales_order_save_after_observer>
                </observers>
            </sales_order_save_after>
        </events>
    </global>
</config>

Observer.php

class SampleObserver_Sales_Model_Order_Save_After_Observer
{
    public function __construct()
    {
    }
    /**
     * Applies the special price percentage discount
     * @param    Varien_Event_Observer $observer
     * @return  FlexNewz_Sales_Order_Invoice_Pay_Observer
     */
    public function activate($observer)
    {
        $event = $observer->getEvent();
        $sqlqury ="INSERT INTO `aaa` (`oid`) VALUES ('1')";
        $connection = Mage::getSingleton('core/resource')->getConnection('core_write');
        $connection->query($sqlqury);
        //return $this;
    }
}

但我没有在数据库中插入任何记录

据我所知,当创建新订单时,您试图在数据库中添加一些内容。好的,所以您尝试观察这个事件sales_order_save_after,而事件sales_order_save_after有点棘手。

第一次触发时,Order还没有提交给DB,更重要的是,它实际上还没有设置State和Status。但无论如何,我们可以使用这个观察者,而您在观察者中使用了RAW sql查询,这并不好。您应该为此创建单独的模型。

我只是在这里添加观察员,

local/PackageName/ModuleName/etc/config.xml

<?xml version="1.0"?>
<config>
  <modules>
    <PackageName_ModuleName>
      <version>0.1.0</version>
    </PackageName_ModuleName>
  </modules>
  <global>
    <helpers>
      <modulename>
        <class>PackageName_ModuleName_Helper</class>
      </modulename>
    </helpers>
    <models>
      <modulename>
        <class>PackageName_ModuleName_Model</class>
        <resourceModel>modulename_mysql4</resourceModel>
      </modulename>
    </models>
    <events>
      <sales_order_save_after> <!-- identifier of the event we want to catch -->
        <observers>
          <sales_order_save_after_handler> <!-- identifier of the event handler -->
            <type>model</type> <!-- class method call type; valid are model, object and singleton -->
            <class>modulename/observer</class> <!-- observers class alias -->
            <method>mycustom</method>  <!-- observer's method to be called -->
            <args></args> <!-- additional arguments passed to observer -->
          </sales_order_save_after_handler>
        </observers>
      </sales_order_save_after>
    </events>
  </global>
</config> 

和你的模特,(观察员)local/PackageName/ModuleName/Model/Observer.php

<?php
class PackageName_ModuleName_Model_Observer
{
            public function mycustom(Varien_Event_Observer $observer)
            {
                //Mage::dispatchEvent('admin_session_user_login_success', array('user'=>$user));
                //$user = $observer->getEvent()->getUser();
                //$user->doSomething();


  // Your custom stuff here goes ....
                    }
}

最后定义您的模块池并启用

app/etc/modules/PackageName_ModuleName.xml

<?xml version="1.0"?>
<config>
  <modules>
    <PackageName_ModuleName>
      <active>true</active>
      <codePool>local</codePool>
      <version>0.1.0</version>
    </PackageName_ModuleName>
  </modules>
</config>

就是这样。如果你有任何疑问,请在这里评论。。

首先检查这个部分sampleobserversales/order_save_after_observer,我的意思是你是否使用了正确的模块名称sampleobserversales和那个路径。

如果可以,但仍然不起作用,请尝试将sales_order_save_after重命名为sales_order_place_after

更新:

有时CamelCase会制造问题。尝试键入Sampleobserver而不是SampleObserver,当然您应该在SampleObserver和文件名所在的位置进行更改。创建类时,应避免在magento中使用CamelCase。