![](/img/trans.png)
[英]Magento - Adding a new column to sales_flat_quote_item and sales_flat_order_item
[英]**update** How i can create new column in table sales_flat_quote_item and add data with $cart->addProduct
如何使用$ cart-> addProduct代碼在sales_flat_quote_item的新列中設置數據
我嘗試以不同的方式插入,但結果是將同一產品添加到購物車,但我的數據未插入數據庫
我無法理解我的問題所在,還是在app \\ code \\ core \\ Mage \\ Checkout \\ sql \\ checkout_setup之前做任何事情?
這是我的exem代碼PS:我在$ cart-> addProduct行上進行更改
1
$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();
第2位。
$param = array(
'product' => $product->getId(),
'qty' => $qty,
'ref_order_id' => $ref_order_id
);
$request = new Varien_Object();
$request->setData($param);
$cart->addProduct($product, $param);
第3
$cart->addProduct($product, array('qty' => $qty,'original_custom_price' => $ref_order_id ));
更新我嘗試將此代碼插入到addProductAdvanced類中
應用/代碼/核心/法師/銷售/模型/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');
...
...
}
但是數據已插入報價中所有項目,我如何檢查這是否來自我的頁面?
可以通過XML配置文件並創建安裝腳本來向sales_flat_order_item表添加新屬性。 有一種特殊的方法可以在任何核心模塊的核心升級和安裝腳本中看到。
您必須將列添加到許多表中,而不僅僅是訂單項。 當客戶將商品添加到他們的購物籃中時,他們正在建立報價。 首先,您需要在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);
}
}
}
您可以通過admin產品屬性系統添加產品屬性,也可以對模塊進行編碼,以使用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',
),
)
)
);
}
}
希望這可以幫助您以正確的方式完成您想做的事情。 只需將其構建為自定義模塊即可。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.