Pregunta

Estoy tratando de descargar detalles de orden (e-mail Nombre +) de mis tiendas. Tenemos una multi-tienda.

El problema que tengo es que cuando ejecuto el código en la tienda o tienda 1 2 - tanto resultado de la colección completa de los pedidos. Lo que necesito es las órdenes que pertenecen a ALMACÉN 1 o 2, etc.

El siguiente fragmento es parte de un PHP en la raíz de mi dominio.

Me trató las tres opciones mencionadas a continuación ...

Mage::app();

[OPTIONS I TRIED]
// ->addAttributeToFilter('store_id', Mage::app()->getStore()->getId())
//->addStoreFilter(Mage::app()->getStore()->getId())
// ->setStoreId(Mage::app()->getStore()->getId())

$orders = Mage::getModel('sales/order')
->getCollection()
[OPTIONS]

¿Cómo puede hacerse esto?

¿Fue útil?

Solución

Esto debería funcionar en las versiones 1.4.0.1+

/* Store or website code */
$mageRunCode = isset($_SERVER['MAGE_RUN_CODE']) ? $_SERVER['MAGE_RUN_CODE'] : '';

/* Run store or run website */
$mageRunType = isset($_SERVER['MAGE_RUN_TYPE']) ? $_SERVER['MAGE_RUN_TYPE'] : 'store';

Mage::app($mageRunCode,$mageRunType);
$orders = Mage::getModel('sales/order')
->getCollection()
->addFieldToFilter('store_id', Mage::app()->getStore()->getId())
->addAttributeToFilter('status', Mage_Sales_Model_Order::STATE_COMPLETE)
->addAttributeToSort('entity_id', 'DESC');

echo "<html><body>";

foreach($orders as $order) {
    echo $order->getCustomerName() . "\t" .
    $order->getCustomerEmail() . "\r\n<br />";
}
Licenciado bajo: CC-BY-SA con atribución
No afiliado a magento.stackexchange
scroll top