Pergunta

Eu tenho um modelo chamado de Armazéns e outro chamado de Armazém de Produtos a que está associado.O problema que estou tendo é que o Armazém de Produtos não salvar, apesar de save() função que está sendo envolvido em um try-catch, que não produz problemas.

try {
    $model->save();
    $session->addSuccess($this->__('The product has been saved.'));
    $this->_redirect('*/*/');

    return;            
} catch (Mage_Core_Exception $e) {
    $session->addError($e->getMessage());
} catch (Exception $e) {
    $session->addError($this->__('An error occurred while saving this product.'));
}

Se eu usar o modelo para retornar a tabela, aparece o seguinte:

$model->getResource()->getTable();
// Can't retrieve entity config

Obviamente, isso sugere que há algo de errado com meu setup -

<inventorymanagement>
    <class>CompanyName_InventoryManagement_Model</class>
    <resourceModel>inventorymanagement_resource</resourceModel>
</inventorymanagement>
<inventorymanagement_resource>
    <class>TheGenieLab_InventoryManagement_Model_Resource</class>
    <entities>
        <warehouse>
            <table>inventorymanagement_warehouse</table>
        </warehouse>
        <warehouse_product>
            <table>inventorymanagement_warehouse_product</table>
        </warehouse_product>
    </entities>
</inventorymanagement_resource>

A seção de recursos:

<resources>
    <inventorymanagement_setup>
        <setup>
            <module>TheGenieLab_InventoryManagement</module>
        </setup>
    </inventorymanagement_setup>
</resources>

Meus arquivos são definidos como a seguir:

- Resource
    - Warehouse
        - Product
            - Collection.php
        - Collection.php
        - Product.php
    - Warehouse.php
- Warehouse
    - Product.php
- Warehouse.php

Há mais alguma coisa que eu preciso fazer?

EDITAR

Aqui está mais algumas código
Armazém > Product.php

class CompanyName_InventoryManagement_Model_Warehouse_Product extends Mage_Core_Model_Abstract
{
    protected function _construct()
    {
        $this->_init('inventorymanagement/warehouse_product');
    }
}

Recurso > Armazém > Product.php

class CompanyName_InventoryManagement_Model_Resource_Warehouse_Product extends Mage_Core_Model_Mysql4_Abstract
{
    protected function _construct()
    {
        $this->_init('inventorymanagement/warehouse_product', 'id');
    }
}

Recurso > Armazém > Produto > Collection.php

class CompanyName_InventoryManagement_Model_Resource_Warehouse_Product_Collection extends Mage_Core_Model_Mysql4_Collection_Abstract
{
    protected function _construct()
    {
        $this->_init('inventorymanagement/warehouse_product');
    }
}
Foi útil?

Solução

Eu já percebi isso.

Antes de o $model->save(); Eu tinha esse:

$model = Mage::getModel('inventorymanagement/warehouse_product');
$product = $postData['warehouse_product'];
if (isset($product['id'])) {
    $model->load($product['id']);
}
$product['product_id'] = str_replace('product/', '', $product['product_id']);
unset($product['save']);
$model->setData($product);

O problema era que quanto $produto['id'] foi definida como um campo oculto no formulário e, em seguida, ele sempre foi definido;assim, o isset de seleção era verdade.Era verão, mas porque o $model->load() o que estava acontecendo, não era verão em qualquer lugar em particular.

Para Além de métodos, tirei essa verificação completamente, juntamente com a instrução de carga, então, eu simplesmente corri esta unset($product['id']); antes de definir os dados.

Tudo funcionando muito bem!

Licenciado em: CC-BY-SA com atribuição
Não afiliado a magento.stackexchange
scroll top