O problema aqui faz parte da função de economia de recursos. O magento verifica se a chave primária está configurada para incremento automático e, em seguida, a remove dos dados que estão sendo salvos, se este for o caso.
Em Mage_Core_Model_Resource_Db_Abstract::save
você pode ver como ele lida com$this->_isPkAutoIncrement
/**
* Not auto increment primary key support
*/
if ($this->_isPkAutoIncrement) {
$data = $this->_prepareDataForSave($object);
unset($data[$this->getIdFieldName()]);
$this->_getWriteAdapter()->update($this->getMainTable(), $data, $condition);
} else {
$select = $this->_getWriteAdapter()->select()
->from($this->getMainTable(), array($this->getIdFieldName()))
->where($condition);
if ($this->_getWriteAdapter()->fetchOne($select) !== false) {
$data = $this->_prepareDataForSave($object);
unset($data[$this->getIdFieldName()]);
if (!empty($data)) {
$this->_getWriteAdapter()->update($this->getMainTable(), $data, $condition);
}
} else {
$this->_getWriteAdapter()->insert($this->getMainTable(), $this->_prepareDataForSave($object));
}
}
Portanto, para corrigir meu problema, simplesmente tenho que definir $_isPkAutoIncrement
o recurso do meu modelo como false e o Magento manterá o PK nos dados e o salvará na tabela.