- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我刚看到 opencart 的一些扩展可以更新产品列表页面的产品,我在我的 opencart 项目中尝试了它,很有趣...现在我开始为我的 opencart 项目开发一个新的扩展,即: Insert Bulk product to admin...这一次最多可以添加10个产品,填写产品表格后只需点击保存按钮这10个产品可以存储到数据库...每个产品表格只有5个以下表单字段,
我可以使用 opencart 默认的产品编辑页面来添加额外的细节/选项/描述,当插入这个批量产品时,只有 3 个下表与我的查询相关联,
我试过一些代码,我的问题是当我点击保存按钮表 product
和 product_description
数据插入功能成功,但 product_id
没有这两个表都是唯一的,例如,如果 product
表 product_id = 125
那么 product_description
表 product_id = 5
,我需要这 3 个表 product_id 必须像我们默认的 opencart 插入工作一样唯一......任何想法..??
我在这里尝试了什么....表单
<input type="text" name="product_description[<?php echo $language['language_id']; ?>][name]" value="<?php echo isset($product_description[$language['language_id']]) ? $product_description[$language['language_id']]['name'] : ''; ?>" />
<input type="text" name="model" value="" />
<input type="text" name="quantity" value="" />
<input type="text" name="price" value="" />
<select name="stock_status_id">
<?php foreach ($stock_statuses as $stock_status) { ?>
<?php if ($stock_status['stock_status_id'] == $stock_status_id) { ?>
<option value="<?php echo $stock_status['stock_status_id']; ?>" selected="selected"><?php echo $stock_status['name']; ?></option>
<?php } else { ?>
<option value="<?php echo $stock_status['stock_status_id']; ?>"><?php echo $stock_status['name']; ?></option>
<?php } ?>
<?php } ?>
</select>
Controller
public function simple_pu() {
$this->load->language('catalog/product');
$this->document->setTitle($this->language->get('heading_title'));
$this->load->model('catalog/product');
if (isset($this->request->post['selected']) && $this->validateSimplePu()) {
$url = '';
foreach ($this->request->post['selected'] as $product_id) {
$price_str = $product_id.'_price';
$quantity_str = $product_id.'_quantity';
$model_str = $product_id.'_model';
$name_str = $product_id.'_name';
$status_str = $product_id.'_status';
$price = $this->request->post[$price_str];
$quantity = $this->request->post[$quantity_str];
$model = $this->request->post[$model_str];
$name = $this->request->post[$name_str];
$status = $this->request->post[$status_str];
$su_data = array('price' => $price, 'quantity' => $quantity, 'model' => $model, 'name' => $name, 'status' => $status);
$this->model_catalog_product->editPrices($product_id, $su_data);
}
$this->redirect($this->url->link('catalog/product', 'token=' . $this->session->data['token'] . $url, 'SSL'));
}
$this->getListbulk();
}
型号
public function addBulkproduct($product_id, $su_data) {
if (isset($su_data['product'])) {
$this->db->query("INSERT INTO " . DB_PREFIX . "product SET price = '" . $this->db->escape($su_data['price']) . "', model = '" . $this->db->escape($su_data['model']) . "', quantity = '" . $this->db->escape($su_data['quantity']) . "', student_id = '" . (int)$student_id . "', date_added = NOW()");
}
if (isset($su_data['product_description'])) {
$this->db->query("UPDATE " . DB_PREFIX . "product_description SET name = '" . $this->db->escape($su_data['name']) . "' WHERE product_id = '" . (int)$product_id . "'");
}
}
就这些....上面的代码只是一个结构如果你知道任何与我的问题相关的扩展,你可以建议我......
谢谢...
最佳答案
您必须更新您的模型。检查 /admin/model/catalog/product.php
和方法 addProduct()
- 插入产品后,您必须检索 $product_id
,所以在你的模型中它应该是这样的:
public function addBulkproduct($su_data) {
if (isset($su_data['product'])) {
$this->db->query("INSERT INTO " . DB_PREFIX . "product SET price = '" . $this->db->escape($su_data['price']) . "', model = '" . $this->db->escape($su_data['model']) . "', quantity = '" . $this->db->escape($su_data['quantity']) . "', student_id = '" . (int)$student_id . "', date_added = NOW()");
$product_id = $this->db->getLastId();
// INSERT INTO PRODUCT TO STORE
$this->db->query("INSERT INTO " . DB_PREFIX . "product_store (store_id, product_id) SELECT store_id, " . (int)$product_id . " FROM " . DB_PREFIX . "store");
if (isset($su_data['product_description'])) {
$this->db->query("INSERT INTO " . DB_PREFIX . "product_description SET name = '" . $this->db->escape($su_data['name']) . "', product_id = '" . (int)$product_id . "'");
}
}
}
请注意,您不再将 $product_id
作为方法参数传递 - 插入产品,生成新 ID,并为该 ID 存储描述。此外,产品说明未更新,但也作为新的插入!仅当插入产品时才存储产品描述 - 即使没有产品数据,存储产品描述也没有意义...
您还应该为产品描述行设置 language_id
。
关于php - Opencart:插入批量产品,product_id 不唯一,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15785097/
我想使用 opencart sellya 主题在标题中显示语言下拉列表。在下面的链接上,您会在标题中看到语言下拉列表。 http://serwer1382018.home.pl/sellyakids/
谁能帮我在 opencart 中向制造商添加元数据详细信息?我正在寻找添加类似于产品或类别的元数据关键字、描述和制造商描述。 最佳答案 打开您的 opencart 数据库并将以下额外字段添加到 oc_
如何在 Opencart 上为运费加税? 我在我的网站上获得了以下结帐摘要: 小计:£332.50送货区 1:49.99 英镑增值税 (20%):66.50 英镑总计:448.99 英镑 运费为 49
我是 OpenCart 的新手,我想将我的主题应用于 OpenCart。 我知道我不应该直接编辑默认模板,但是如何复制默认模板文件并更改它以应用主题? 最佳答案 Balan,您可以从复制文件夹目录\v
我想在产品描述页面上显示货币列表。我该怎么做? 我从 header.tpl () 中复制代码并将其粘贴到 product.tpl 中,但出现错误: 注意: undefined variable :C:
我想在产品描述页面上显示货币列表。我该怎么做? 我从 header.tpl () 中复制代码并将其粘贴到 product.tpl 中,但出现错误: 注意: undefined variable :C:
我正在尝试创建一个开发站点,我可以在其中将产品添加到我的购物车和交付选项 - 然后结帐。我希望能够在不使用真实卡或支付网关的情况下执行虚拟订单 我启用了免费结账功能,但它没有出现在 OpenCart
我刚刚第 5 次安装 OpenCart,但我总是卡在同一页面上.. 我在安装时没有遇到任何错误,但是当我尝试登录到管理页面时,我总是卡住。如果我尝试使用正确的用户名/密码,它不会显示任何错误。 这里有
我正在使用 OpenCart 版本 3.0.2。 默认情况下,OpenCart 有 4 个区域,我们可以在其中放置模块到我们的布局中。即 左栏 右栏 热门内容 底部内容 我的问题是,我们是否可以以某种
除产品选项外,我的购物车似乎正常运行。当我单击“添加购物车”按钮时,会添加该项目,但不会添加任何选项。我真的不明白为什么会发生这种情况,因为我已经按照函数的需要,使用 option_id 和 opti
如果有2个vQmod /vqmod/xml/mymod1.xml & /vqmod/xml/mymod2.xml 来更改文件(例如) Catalog/model/tool/image.php,在 Op
我已经复制了一份 OpenCart 安装(版本 2.0.3.1)并放到 Windows localhost 上。 我已经解决了几个问题,但现在遇到了一个我无法解决的错误: fatal error :在
我正在编写 VQMod XML 以在 opencart 中编辑 config.php,我在 XML 下方编写并将其保存在 XML 文件夹中。 VQMOD CORE FOR OPENCART - DO
我想从 opencart 2.0 及以上版本的注册、 guest 中删除送货地址或送货地址选项,但送货方式应该在那里,因为我希望账单地址是没有额外字段的送货地址 我试图通过这两个教程在我的 openc
我是这个论坛和 OpenCart 的新手。 我需要有关在 OpenCart 中创建模块的帮助。在我的例子中,它将从我的 WordPress 安装的每个类别中获取最新的 5 个帖子,并将其显示在我的 O
我在 OpenCart 中遇到问题。 当为产品填充 SEO 关键字时,它在 Firefox 和 Chrome 上运行良好,但在 IE(版本 6.)上它崩溃了。 错误: The page you are
我已将我的产品导出到 Excel 电子表格文件中,然后我将我的产品安装到全新安装的 OpenCart 1.5.6.4 中。然后我上传了 OpenCart 2.0.3.1 并运行了升级脚本。我第一次运行
我一直在尝试使用默认模板并尝试更改它的一些功能。在我的产品页面 (catalog/view/theme/mytheme/template/product/product.tpl) 上,我想根据我的客户
在 opencart 版本 3 中有一条通知: It is very imporant that you move the storage directory outside of the web d
我的 OpenCart 网站使用 SendGrid 作为其电子邮件发送系统。直到最近,这一切都正常工作。使用需要向管理员发送电子邮件的功能时(例如,新订单提醒电子邮件、创建新帐户),我收到此错误:
我是一名优秀的程序员,十分优秀!