Modelo que no se guarda en la base de datos
-
12-12-2019 - |
Pregunta
Tengo un modelo que se llama Almacenes y otro que se llama Almacén de Productos que está asociado.El problema que tengo es que Warehouse Products no guarda, a pesar de que está save()
La función está envuelta en un try-catch que no produce 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.'));
}
Si uso el modelo para devolver la tabla, obtengo lo siguiente:
$model->getResource()->getTable();
// Can't retrieve entity config
Obviamente, esto sugiere que hay algo mal con mi configuración.
<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>
La sección de recursos:
<resources>
<inventorymanagement_setup>
<setup>
<module>TheGenieLab_InventoryManagement</module>
</setup>
</inventorymanagement_setup>
</resources>
Mis archivos se presentan de la siguiente manera:
- Resource
- Warehouse
- Product
- Collection.php
- Collection.php
- Product.php
- Warehouse.php
- Warehouse
- Product.php
- Warehouse.php
¿Hay algo más que deba hacer?
EDITAR
Aquí hay más código
Almacén > Producto.php
class CompanyName_InventoryManagement_Model_Warehouse_Product extends Mage_Core_Model_Abstract
{
protected function _construct()
{
$this->_init('inventorymanagement/warehouse_product');
}
}
Recurso > Almacén > Producto.php
class CompanyName_InventoryManagement_Model_Resource_Warehouse_Product extends Mage_Core_Model_Mysql4_Abstract
{
protected function _construct()
{
$this->_init('inventorymanagement/warehouse_product', 'id');
}
}
Recurso > Almacén > Producto > Colección.php
class CompanyName_InventoryManagement_Model_Resource_Warehouse_Product_Collection extends Mage_Core_Model_Mysql4_Collection_Abstract
{
protected function _construct()
{
$this->_init('inventorymanagement/warehouse_product');
}
}
Solución
Lo he descubierto.
Antes de la $model->save();
Tuve esto:
$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);
El problema era que como $product['id'] se establecía como un campo oculto en el formulario, siempre se configuraba;por lo tanto, la verificación de isset era verdadera.Era un ahorro, pero debido a que $model->load()
estaba sucediendo, no estaba guardando ningún lugar en particular.
Para los métodos de suma, eliminé esta verificación por completo junto con la declaración de carga, luego simplemente ejecuté esto unset($product['id']);
antes de configurar los datos.
¡Todo funciona muy bien!