**更新** 我如何在 table sales_flat_quote_item 中创建新列并使用 $cart->addProduct 添加数据
**update** How i can create new column in table sales_flat_quote_item and add data with $cart->addProduct
如何使用 $cart->addProduct code
在 sales_flat_quote_item 的新列中设置数据
我尝试以不同的方式插入,但结果是相同的产品被添加到购物车,但我的数据没有插入数据库
我不明白我有什么问题,或者我只是在 app\code\core\Mage\Checkout\sql\checkout_setup 之前做了什么?
这是我的执行代码
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 class 中插入此代码
app/code/core/Mage/Sales/Model/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');
...
...
}
但是报价中的所有项目都插入了数据,我如何检查这是否来自我的页面?
向 sales_flat_order_item table 添加新属性可以通过 XML 配置文件和创建安装脚本来实现。有一种特殊的方法可以在核心模块的任何核心升级和安装脚本中看到。
您必须将列添加到许多 table 中,而不仅仅是订单项。当客户将商品添加到他们的购物篮时,他们正在建立报价。您首先需要 sales_flat_quote_item table 上的需求列,这样当客户将商品添加到购物车时,数据就会根据报价存储。
当客户下订单时,报价单会转换为订单,因此您还需要将报价单中的所有商品数据转移到订单商品中。这是模块配置中的 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();
这样做是将这些列作为模块安装脚本的一部分很好地添加到您的 table 中。
然后在你的模块 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 table 复制到 order_item table。上面的示例还从订单中将值复制到贷项通知单项目和发票项目。
神奇的一点是当客户将商品添加到他们的购物篮时首先设置报价商品数据的观察者。
<?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',
),
)
)
);
}
}
希望这能帮助您以正确的方式实现您想做的事情。只需将其全部构建为自定义模块即可。
如何使用 $cart->addProduct code
在 sales_flat_quote_item 的新列中设置数据我尝试以不同的方式插入,但结果是相同的产品被添加到购物车,但我的数据没有插入数据库
我不明白我有什么问题,或者我只是在 app\code\core\Mage\Checkout\sql\checkout_setup 之前做了什么?
这是我的执行代码 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 class 中插入此代码app/code/core/Mage/Sales/Model/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');
...
...
}
但是报价中的所有项目都插入了数据,我如何检查这是否来自我的页面?
向 sales_flat_order_item table 添加新属性可以通过 XML 配置文件和创建安装脚本来实现。有一种特殊的方法可以在核心模块的任何核心升级和安装脚本中看到。
您必须将列添加到许多 table 中,而不仅仅是订单项。当客户将商品添加到他们的购物篮时,他们正在建立报价。您首先需要 sales_flat_quote_item table 上的需求列,这样当客户将商品添加到购物车时,数据就会根据报价存储。
当客户下订单时,报价单会转换为订单,因此您还需要将报价单中的所有商品数据转移到订单商品中。这是模块配置中的 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();
这样做是将这些列作为模块安装脚本的一部分很好地添加到您的 table 中。
然后在你的模块 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 table 复制到 order_item table。上面的示例还从订单中将值复制到贷项通知单项目和发票项目。
神奇的一点是当客户将商品添加到他们的购物篮时首先设置报价商品数据的观察者。
<?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',
),
)
)
);
}
}
希望这能帮助您以正确的方式实现您想做的事情。只需将其全部构建为自定义模块即可。