mysql - 在mysql查询中包含批发字段

标签 mysql opencart

我使用的是 Opencart 2.2.0。我有两个客户群 - 默认客户和批发客户。在我的网站中,price 字段用于默认组,wholesale 字段用于批发客户组。我还在特价选项卡中添加了批发字段(到 oc_product_special 表),一切正常(它会记住管理中的值,并通过特价添加到购物车)前端两组的价格。)我唯一的问题是它在前端没有正确显示。这意味着它显示两个客户组的特殊价格字段的值,而不是显示批发客户的批发特殊价格。我找出了问题所在 - 在模型/目录/产品文件中的查询中。我想知道如何更改以下查询,以便我可以包含批发字段,因为只有这样我才能在前端显示它。我的查询是:

$query = $this->db->query("SELECT DISTINCT *, pd.name AS name, p.image, m.name AS manufacturer, (SELECT price FROM " . DB_PREFIX . "product_discount pd2 WHERE pd2.product_id = p.product_id AND pd2.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND pd2.quantity = '1' AND ((pd2.date_start = '0000-00-00' OR pd2.date_start < NOW()) AND (pd2.date_end = '0000-00-00' OR pd2.date_end > NOW())) ORDER BY pd2.priority ASC, pd2.price ASC LIMIT 1) AS discount, **(SELECT price FROM " . DB_PREFIX . "product_special ps WHERE ps.product_id = p.product_id AND ps.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND ((ps.date_start = '0000-00-00' OR ps.date_start < NOW()) AND (ps.date_end = '0000-00-00' OR ps.date_end > NOW())) ORDER BY ps.priority ASC, ps.price ASC LIMIT 1) AS special,** (SELECT points FROM " . DB_PREFIX . "product_reward pr WHERE pr.product_id = p.product_id AND customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "') AS reward, (SELECT ss.name FROM " . DB_PREFIX . "stock_status ss WHERE ss.stock_status_id = p.stock_status_id AND ss.language_id = '" . (int)$this->config->get('config_language_id') . "') AS stock_status, (SELECT wcd.unit FROM " . DB_PREFIX . "weight_class_description wcd WHERE p.weight_class_id = wcd.weight_class_id AND wcd.language_id = '" . (int)$this->config->get('config_language_id') . "') AS weight_class, (SELECT lcd.unit FROM " . DB_PREFIX . "length_class_description lcd WHERE p.length_class_id = lcd.length_class_id AND lcd.language_id = '" . (int)$this->config->get('config_language_id') . "') AS length_class, (SELECT AVG(rating) AS total FROM " . DB_PREFIX . "review r1 WHERE r1.product_id = p.product_id AND r1.status = '1' GROUP BY r1.product_id) AS rating, (SELECT COUNT(*) AS total FROM " . DB_PREFIX . "review r2 WHERE r2.product_id = p.product_id AND r2.status = '1' GROUP BY r2.product_id) AS reviews, p.sort_order FROM " . DB_PREFIX . "product p LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id) LEFT JOIN " . DB_PREFIX . "manufacturer m ON (p.manufacturer_id = m.manufacturer_id) WHERE p.product_id = '" . (int)$product_id . "' AND pd.language_id = '" . (int)$this->config->get('config_language_id') . "' AND p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "'");

查询中特殊的部分是:

(SELECT price FROM " . DB_PREFIX . "product_special ps WHERE ps.product_id = p.product_id AND ps.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND ((ps.date_start = '0000-00-00' OR ps.date_start < NOW()) AND (ps.date_end = '0000-00-00' OR ps.date_end > NOW())) ORDER BY ps.priority ASC, ps.price ASC LIMIT 1) AS special,

谢谢

最佳答案

我解决了这个问题...如果有人被困在同一个地方,这就是我所做的:

向查询添加了另一行(子查询),其中我定义了special_wholesale,如下所示:

SELECT wholesale FROM " . DB_PREFIX . "product_special ps WHERE ps.product_id = p.product_id AND ps.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND ((ps.date_start = '0000-00-00' OR ps.date_start < NOW()) AND (ps.date_end = '0000-00-00' OR ps.date_end > NOW())) ORDER BY ps.priority ASC, ps.wholesale ASC LIMIT 1) AS special_wholesale

以及定义'special_wholesale' => $query->row['special_wholesale'] ,在查询数组中 'special' 下面catalog/model/catalog/product.php 中的数组元素public function getProduct($product_id)内的文件功能。

之后,我定义了$special_wholesale特色产品的 Controller 文件中的变量(/catalog/controller/module/featured.php)。

我做的最后一件事是调用 $product['special_wholesale'];在featured.php (/catalog/view/theme/your-theme-name/template/module/featured.tpl)像这样的文件:

<font size="2" color="red"> <span class="price-new"><?php echo "VP:" . $product['special_wholesale']; ?></span>&nbsp;<span class="price-old"><?php echo "VP:". $product['wholesale']; ?></span></font></br>

输出为:删除旧批发价并显示特价批发价。

我希望这可以帮助别人。干杯!

关于mysql - 在mysql查询中包含批发字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51362704/

相关文章:

.htaccess - 替换长 URL 的一部分并重定向

mysql - 执行计算 SQL

php - Opencart 管理员 Cron 作业

php - 如何在 OpenCart .tpl 文件中获取当前 url?

php - 为什么 MySQL 不返回最后插入的 id,它返回 0?

php - 插入两个不同的表

mysql - 从 A 表的一行中进行多项选择,并将结果作为多行插入 B 表中,并在一个查询中重复

android - 使用 where 条件进行 Sqlite 查询需要满足多个条件

mysql - 是否可以为用户设置数据库行级权限?

javascript - 使用 Opencart 在我的 Controller 中无法识别 POST 请求