Skip to content

Commit 67758af

Browse files
author
Joan He
committed
Merge branch 'MAGETWO-32012-new' of https://github.corp.ebay.com/magento-extensibility/magento2ce into MAGETWO-32012-new
2 parents 6aa5060 + 6a07c85 commit 67758af

File tree

2 files changed

+11
-12
lines changed

2 files changed

+11
-12
lines changed

lib/internal/Magento/Framework/Model/AbstractModel.php

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -132,7 +132,7 @@ abstract class AbstractModel extends \Magento\Framework\Object
132132
*
133133
* @var array
134134
*/
135-
private $storedData = [];
135+
protected $storedData = [];
136136

137137
/**
138138
* @param \Magento\Framework\Model\Context $context
@@ -705,7 +705,7 @@ protected function _clearData()
705705
*
706706
* @return $this
707707
*/
708-
protected function updateStoredData()
708+
private function updateStoredData()
709709
{
710710
if (isset($this->_data)) {
711711
$this->storedData = $this->_data;

lib/internal/Magento/Framework/Model/Resource/Db/AbstractDb.php

Lines changed: 9 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -417,9 +417,7 @@ public function save(\Magento\Framework\Model\AbstractModel $object)
417417
* Not auto increment primary key support
418418
*/
419419
if ($this->_isPkAutoIncrement) {
420-
$data = $this->_prepareDataForSave($object);
421-
unset($data[$this->getIdFieldName()]);
422-
$data = $this->prepareDataForUpdate($data, $object->getStoredData());
420+
$data = $this->prepareDataForUpdate($object);
423421
if (!empty($data)) {
424422
$this->_getWriteAdapter()->update($this->getMainTable(), $data, $condition);
425423
}
@@ -431,9 +429,7 @@ public function save(\Magento\Framework\Model\AbstractModel $object)
431429
$condition
432430
);
433431
if ($this->_getWriteAdapter()->fetchOne($select) !== false) {
434-
$data = $this->_prepareDataForSave($object);
435-
unset($data[$this->getIdFieldName()]);
436-
$data = $this->prepareDataForUpdate($data, $object->getStoredData());
432+
$data = $this->prepareDataForUpdate($object);
437433
if (!empty($data)) {
438434
$this->_getWriteAdapter()->update($this->getMainTable(), $data, $condition);
439435
}
@@ -778,17 +774,20 @@ public function getChecksum($table)
778774
/**
779775
* Get the array of data fields that was changed or added
780776
*
781-
* @param array $data
782-
* @param array $storedData
777+
* @param \Magento\Framework\Model\AbstractModel $object
783778
* @return array
784779
*/
785-
protected function prepareDataForUpdate($data, $storedData)
780+
protected function prepareDataForUpdate($object)
786781
{
787-
foreach ($storedData as $key => $value) {
782+
$data = $this->_prepareDataForSave($object);
783+
unset($data[$this->getIdFieldName()]);
784+
785+
foreach ($object->getStoredData() as $key => $value) {
788786
if(array_key_exists($key, $data) && $data[$key] == $value) {
789787
unset($data[$key]);
790788
}
791789
}
790+
792791
return $data;
793792
}
794793
}

0 commit comments

Comments
 (0)