#116674 Исследование путей решения проблем дублирования записей в таблицах price, price_value, supply, rest_item
This commit is contained in:
		@@ -2,6 +2,8 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
namespace dominion\db;
 | 
					namespace dominion\db;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					use Yii;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
@@ -33,4 +35,87 @@ class ActiveRecord extends \yii\db\ActiveRecord
 | 
				
			|||||||
    {
 | 
					    {
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public function insertUpdate($runValidation = true, $attributes = null)
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        if ($runValidation && !$this->validate($attributes)) {
 | 
				
			||||||
 | 
					            Yii::info('Model not inserted due to validation error.', __METHOD__);
 | 
				
			||||||
 | 
					            return false;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (!$this->isTransactional(self::OP_INSERT)) {
 | 
				
			||||||
 | 
					            return $this->insertUpdateInternal($attributes);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        $transaction = static::getDb()->beginTransaction();
 | 
				
			||||||
 | 
					        try {
 | 
				
			||||||
 | 
					            $result = $this->insertUpdateInternal($attributes);
 | 
				
			||||||
 | 
					            if ($result === false) {
 | 
				
			||||||
 | 
					                $transaction->rollBack();
 | 
				
			||||||
 | 
					            } else {
 | 
				
			||||||
 | 
					                $transaction->commit();
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            return $result;
 | 
				
			||||||
 | 
					        } catch (\Exception $e) {
 | 
				
			||||||
 | 
					            $transaction->rollBack();
 | 
				
			||||||
 | 
					            throw $e;
 | 
				
			||||||
 | 
					        } catch (\Throwable $e) {
 | 
				
			||||||
 | 
					            $transaction->rollBack();
 | 
				
			||||||
 | 
					            throw $e;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    protected function insertUpdateInternal($attributes = null)
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        if (!$this->beforeSave(true)) {
 | 
				
			||||||
 | 
					            return false;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        $values = $this->getDirtyAttributes($attributes);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (($primaryKeys = $this->schemaInsertUpdate(static::tableName(), $values)) === false) {
 | 
				
			||||||
 | 
					            return false;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        foreach ($primaryKeys as $name => $value) {
 | 
				
			||||||
 | 
					            $id = static::getTableSchema()->columns[$name]->phpTypecast($value);
 | 
				
			||||||
 | 
					            $this->setAttribute($name, $id);
 | 
				
			||||||
 | 
					            $values[$name] = $id;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        $changedAttributes = array_fill_keys(array_keys($values), null);
 | 
				
			||||||
 | 
					        $this->setOldAttributes($values);
 | 
				
			||||||
 | 
					        $this->afterSave(true, $changedAttributes);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        return true;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public function schemaInsertUpdate($table, $columns)
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        $db = static::getDb();
 | 
				
			||||||
 | 
					        foreach ($this->attributes() as $itemColumn) {
 | 
				
			||||||
 | 
					            $column = $db->getSchema()->quoteColumnName($itemColumn);
 | 
				
			||||||
 | 
					            $onDuplicateKeyValues[] = $column . ' = VALUES(' . $column . ')';
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        $command = $db->createCommand()->insert($table, $columns);
 | 
				
			||||||
 | 
					        $sql = $command->getRawSql();
 | 
				
			||||||
 | 
					        $sql .= ' ON DUPLICATE KEY UPDATE ' . implode(', ', $onDuplicateKeyValues);;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (!$db->createCommand($sql)->execute()) {
 | 
				
			||||||
 | 
					            return false;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        $tableSchema = $this->getTableSchema($table);
 | 
				
			||||||
 | 
					        $result = [];
 | 
				
			||||||
 | 
					        foreach ($tableSchema->primaryKey as $name) {
 | 
				
			||||||
 | 
					            if ($tableSchema->columns[$name]->autoIncrement) {
 | 
				
			||||||
 | 
					                $result[$name] = $this->getLastInsertID($tableSchema->sequenceName);
 | 
				
			||||||
 | 
					                break;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            $result[$name] = isset($columns[$name]) ? $columns[$name] : $tableSchema->columns[$name]->defaultValue;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return $result;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user