- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何使用 $cart->addProduct 代码在 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 类中
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');
...
...
}
但是数据已插入报价中的所有项目,我如何检查这是否来 self 的页面?
最佳答案
向 sales_flat_order_item 表添加新属性可以通过 XML 配置文件并创建安装脚本来实现。有一种特殊的方法可以做到这一点,可以在核心模块的任何核心升级和安装脚本中看到。
您必须将该列添加到许多表中,而不仅仅是订单项。当客户将商品添加到购物篮时,他们正在建立报价。您首先需要 sales_flat_quote_item 表上的 need 列,以便当客户将商品添加到购物篮时,数据将根据报价进行存储。
当客户下订单时,报价将转换为订单,因此您还需要将报价中的所有商品数据转入订单商品。这是可以使用模块配置中的 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',
),
)
)
);
}
}
希望这能帮助您以正确的方式实现您想做的事情。只需将其全部构建为自定义模块即可。
关于php - **更新** 我如何在表 sales_flat_quote_item 中创建新列并使用 $cart->addProduct 添加数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27937681/
我正在 csv 上使用 hadoop 来分析一些数据。我使用sql/mysql(不确定)来分析数据,现在陷入了僵局。 我花了好几个小时在谷歌上搜索,却没有找到任何相关的东西。我需要一个查询,在该查询中
我正在为 Bootstrap 网格布局的“简单”任务而苦苦挣扎。我希望在大视口(viewport)上有 4 列,然后在中型设备上有 2 列,最后在较小的设备上只有 1 列。 当我测试我的代码片段时,似
对于这个令人困惑的标题,我深表歉意,我想不出这个问题的正确措辞。相反,我只会给你背景信息和目标: 这是在一个表中,一个人可能有也可能没有多行数据,这些行可能包含相同的 activity_id 值,也可
具有 3 列的数据库表 - A int , B int , C int 我的问题是: 如何使用 Sequelize 结果找到 A > B + C const countTasks = await Ta
我在通过以下功能编写此查询时遇到问题: 首先按第 2 列 DESC 排序,然后从“不同的第 1 列”中选择 只有 Column1 是 DISTINCT 此查询没有帮助,因为它首先从第 1 列中进行选择
使用 Bootstrap 非常有趣和有帮助,目前我在创建以下需求时遇到问题。 “使用 bootstrap 在桌面上有 4 列,在平板电脑上有 2 列,在移动设备上有 1 列”谁能告诉我正确的结构 最佳
我是 R 新手,正在问一个非常基本的问题。当然,我在尝试从所提供的示例中获取指导的同时做了功课here和 here ,但无法在我的案例中实现这个想法,即可能是由于我的问题中的比较维度更大。 我的实
通常我会使用 R 并执行 merge.by,但这个文件似乎太大了,部门中的任何一台计算机都无法处理它! (任何从事遗传学工作的人的附加信息)本质上,插补似乎删除了 snp ID 的 rs 数字,我只剩
我有一个 df , delta1 delta2 0 -1 2 0 -1 0 0 0 我想知道如何分配 delt
您好,我想知道是否可以执行以下操作。显然,我已经尝试在 phpMyAdmin 中运行它,但出现错误。也许还有另一种方式来编写此查询。 SELECT * FROM eat_eat_restaurants
我有 2 个列表(标题和数据值)。我想要将数据值列 1 匹配并替换为头文件列 1,以获得与 dataValue 列 1 和标题值列 2 匹配的值 头文件 TotalLoad,M0001001 Hois
我有两个不同长度的文件,file2 是一个很大的引用文件,我从中提取文件 1 的数据。 我有一行 awk,我通常会对其进行调整以在我的文件中进行查找和替换,但它总是在同一列中进行查找和替换。 所以对于
假设我有两个表,如下所示。 create table contract( c_ID number(1) primary key, c_name varchar2(50) not
我有一个带有 varchar 列的 H2 表,其检查约束定义如下: CONSTRAINT my_constraint CHECK (varchar_field <> '') 以下插入语句失败,但当我删
这是最少量的代码,可以清楚地说明我的问题: One Two Three 前 2 个 div 应该是 2 个左列。第三个应该占据页面的其余部分。最后,我将添加选项来隐藏和
在 Azure 中的 Log Analytics 中,我为 VM Heartbeat 选择一个预定义查询,我在编辑器中运行查询正常,但当我去创建警报时,我不断收到警报“查询未返回 TimeGenera
在 Azure 中的 Log Analytics 中,我为 VM Heartbeat 选择一个预定义查询,我在编辑器中运行查询正常,但当我去创建警报时,我不断收到警报“查询未返回 TimeGenera
今天我开始使用 JexcelApi 并遇到了这个:当您尝试从特定位置获取元素时,不是像您通常期望的那样使用sheet.getCell(row,col),而是使用sheet.getCell(col,ro
我有一个包含 28 列的数据库。第一列是代码,第二列是名称,其余是值。 public void displayData() { con.Open(); MySqlDataAdapter
我很沮丧:每当我缩小这个网页时,一切都变得一团糟。我如何将网页居中,以便我可以缩小并且元素不会被错误定位。 (它应该是 2 列,但所有内容都合并为 1)我试过 但由于某种原因,这不起作用。 www.o
我是一名优秀的程序员,十分优秀!