** обновление ** Как я могу создать новый столбец в таблице sales_flat_quote_item и добавить данные с помощью $ cart-> gt; addProduct

Как я могу установить данные в новом столбце в sales_flat_quote_item с помощью $ cart-> addProduct code

Я пытаюсь вставить по-другому, но результат тот же продукт добавлен в корзину, но мои данные не вставляются в базу данных

я не могу понять, что со мной не так, или я просто делаю что-нибудь раньше в app \ code \ core \ Mage \ Checkout \ sql \ checkout_setup?

Это мой код exem
PS: меняю на $ cart-> addProduct line

первый

$cart = Mage::getSingleton('checkout/cart');
$cart->init();
$cart->addProduct($product, array('qty' => $qty), array('ref_order_id' => $ref_order_id));
Mage::getSingleton('checkout/session')->setCartWasUpdated(true);
$cart->save();

Второй.

$param = array(
'product' => $product->getId(),
'qty' => $qty,
'ref_order_id' => $ref_order_id
);
$request = new Varien_Object();
$request->setData($param);
$cart->addProduct($product, $param);

третий

$cart->addProduct($product, array('qty' => $qty,'original_custom_price' => $ref_order_id ));

ОБНОВИТЬ
я пытаюсь вставить этот код в классе addProductAdvanced в

Приложение / код / ​​ядро ​​/ Mage / Продажа / Модель / Quote.php:
addProduct (Mage_Catalog_Model_Product $ product, $ request = null)

foreach ($cartCandidates as $candidate) {
$item = $this->_addCatalogProduct($candidate, $candidate->getCartQty());
...
...
...
$item->setref_order_id('SpecialOrderFromCustomPage');
...
...
}

но данные вставляются для всего элемента в цитате, как я могу проверить, если это с моей страницы?

0

Решение

Добавление нового атрибута в таблицу sales_flat_order_item может быть достигнуто с помощью XML-файла конфигурации и создания сценария установки. Для этого существует особый метод, который можно увидеть в любом из сценариев обновления ядра и установки модулей ядра.

Вы должны добавить столбец во многие таблицы, а не только в элемент заказа. Когда покупатель добавляет товары в свою корзину, он формирует предложение. Сначала вам понадобится столбец потребности в таблице sales_flat_quote_item, поэтому, когда покупатель добавляет товар в корзину, данные сохраняются вместе с предложением.

Когда заказчик размещает заказ, предложение преобразуется в заказ, поэтому вам нужны все данные об изделии из предложения, перенесенного в элемент заказа. Это где XML в конфигурации вашего модуля может быть использован для достижения желаемого результата. Вам также понадобится наблюдатель, чтобы сопоставить данные с элементом цитаты, когда покупатель нажмет кнопку добавить в корзину.

Рассмотрим следующий пример;

У вас есть продукт, для которого настроен пользовательский атрибут депозита.

Затем вы хотите, чтобы это значение сохранялось в позиции предложения и позиции заказа, когда клиент хочет или покупает этот элемент. Таким образом, вы создаете скрипт установки, подобный следующему в вашем пользовательском модуле;

<?php

$installer = $this;

$installer->installEntities();

$setup = new Mage_Sales_Model_Mysql4_Setup('core_setup');
$setup->startSetup();

$setup->addAttribute(
'order_item',
'base_deposit_price',
array(
'type' => Varien_Db_Ddl_Table::TYPE_DECIMAL,'default' => 0,'visible' => true
)
);

$setup->addAttribute(
'quote_item',
'base_deposit_price',
array(
'type' => Varien_Db_Ddl_Table::TYPE_DECIMAL,'default' => 0,'visible' => true
)
);

$setup->addAttribute(
'invoice_item',
'base_deposit_price',
array(
'type' => Varien_Db_Ddl_Table::TYPE_DECIMAL,'default' => 0,'visible' => true,
)
);

$setup->addAttribute(
'creditmemo_item',
'base_deposit_price',
array(
'type' => Varien_Db_Ddl_Table::TYPE_DECIMAL,'default' => 0,'visible' => true
)
);

$setup->endSetup();

Что это делает, так это добавляет столбцы в ваши таблицы как часть вашего скрипта установки модуля.

Затем в вашем файле config.xml модулей вам нужно что-то вроде следующего определения XML;

<?xml version="1.0"?>
<config>
<global>
<sales>
<quote>
<item>
<product_attributes>
<base_deposit_price />
</product_attributes>
</item>
</quote>
<order>
<item>
<product_attributes>
<base_deposit_price />
</product_attributes>
</item>
</order>
</sales>
<fieldsets>
<sales_convert_quote_item>
<base_deposit_price>
<to_order_item>*</to_order_item>
</base_deposit_price>
</sales_convert_quote_item>
<sales_convert_order_item>
<base_deposit_price>
<to_cm_item>*</to_cm_item>
<to_invoice_item>*</to_invoice_item>
</base_deposit_price>
</sales_convert_order_item>
</fieldsets>
<events>
<sales_quote_item_set_product>
<observers>
<quoteitem_set_deposit_data>
<type>singleton</type>
<class>YourNameSpace_YourModule_Model_Observer</class>
<method>setDepositOnQuoteItem</method>
</quoteitem_set_deposit_data>
</observers>
</sales_quote_item_set_product>
</events>
</global>
</config>

В файле конфигурации есть некоторые определения, которые в основном позволяют magento автоматически копировать значения из таблицы quote_item в таблицу order_item. В приведенном выше примере также копируются значения для зачисления на заметки и счета-фактуры из заказа.

Волшебный бит — это наблюдатель, который в первую очередь устанавливает данные об элементе цитаты, когда покупатель добавляет элемент в свою корзину.

<?php

class YourNameSpace_YpurModule_Model_Observer {

/**
* Flag to stop observer executing more than once
*
* @var static bool
*/
static protected $_singletonFlag = false;

/*
* Gets Deposit Price Values For Quote Product Items. These Will Later Be
* Be Converted To Order Items, Invoice Items, & Credit Memo Items.
*
*/

public function setDepositOnQuoteItem($oObserver) {
$oProduct = $oObserver->getProduct();
$oQuoteItem = $oObserver->getQuoteItem();
$deposit = $oProduct->getData('deposit_price', null);

if ($deposit > 0) {
$oQuoteItem->setData('base_deposit_price', $deposit);
}
}
}

Вы можете добавить свой атрибут продукта через систему атрибутов продукта администратора или кодировать свой модуль, чтобы также настроить пользовательский атрибут продукта, который вы хотите поместить в элемент квоты и элемент заказа, а также с помощью сценария установки EAV;

class YourNameSpace_YourModule_Model_Resource_Eav_Mysql4_Setup extends Mage_Eav_Model_Entity_Setup
{

public function getDefaultEntities()
{
return array(
'catalog_product' => array(
'entity_model'      => 'catalog/product',
'attribute_model'   => 'catalog/resource_eav_attribute',
'table'             => 'catalog/product',
'additional_attribute_table' => 'catalog/eav_attribute',
'entity_attribute_collection' => 'catalog/product_attribute_collection',
'attributes'        => array(
'deposit_price' => array(
'group'             => 'Prices',
'label'             => 'Deposit Price',
'type'              => 'decimal',
'input'             => 'price',
'default'           => '0',
'class'             => 'validate-number',
'frontend'          => '',
'source'            => '',
'global'            => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_STORE,
'visible'           => true,
'required'          => false,
'user_defined'      => false,
'searchable'        => false,
'filterable'        => false,
'comparable'        => true,
'visible_on_front'  => true,
'visible_in_advanced_search' => false,
'unique'            => false,
'backend'           => 'catalog/product_attribute_backend_price',
),
)
)
);
}
}

Надеюсь, это поможет вам достичь того, что вы хотите сделать правильно. Просто соберите все как пользовательский модуль.

1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]