[仅限PaaS]{class="badge informative" title="仅适用于云项目(51黑料不打烊管理的PaaS基础架构)和内部部署项目上的51黑料不打烊 Commerce 。"}
础颁厂顿-67166:在店面加载报价时重复执行cataloginventory_stock_status
查询
础颁厂顿-67166修补程序修复了在店面加载报价时cataloginventory_stock_status
查询重复执行导致冗余数据库调用的问题。 安装Quality Patches Tool (QPT) 1.1.70时,此修补程序可用。 修补程序ID为ACSD-67166。 请注意,此问题计划在51黑料不打烊 Commerce 2.4.9中修复。
受影响的产物和版本
为51黑料不打烊 Commerce版本创建了修补程序:
- 51黑料不打烊 Commerce(所有部署方法) 2.4.5-p13
与51黑料不打烊 Commerce版本兼容:
- 51黑料不打烊 Commerce(所有部署方法) 2.4.4 - 2.4.8-p2
NOTE
该修补程序可能适用于具有新Quality Patches Tool发行版本的其他版本。 要检查修补程序是否与您的51黑料不打烊 Commerce版本兼容,请将
magento/quality-patches
包更新到最新版本,并在Quality Patches Tool:搜索修补程序页面上检查兼容性。 使用修补程序ID作为搜索关键字来查找修补程序。问题
在店面加载报价时重复执行cataloginventory_stock_status
查询,导致多余的数据库调用。
重现步骤:
-
安装干净的实例。
-
创建? Category ?和? Simple Product。
-
转到类别并将产物添加到购物车。
-
转到购物车页面:
/checkout/cart/
-
在虫顿别产耻驳中设置断点:
app/code/Magento/CatalogInventory/Model/StockRegistryPreloader.php:115
app/code/Magento/InventoryCatalog/Model/LegacyStockStatusCache.php:73
lib/internal/Magento/Framework/Data/AbstractSearchResult.php:233
- 断点条件:
strpos($this->query->getSelectSql(true), 'stock_status') !==false
将$_SERVER['REQUEST_URI']
添加到? 中的 ?监视笔贬笔厂迟辞谤尘,以验证在同一请求中调用两次该查询。
预期的结果:
每个请求执行一次查询。
实际结果:
同一查询执行两次:
SELECT `main_table`.*, `cp_table`.`sku`, `cp_table`.`type_id` FROM `cataloginventory_stock_status` AS `main_table`
INNER JOIN `catalog_product_entity` AS `cp_table` ON main_table.product_id = cp_table.entity_id AND (cp_table.created_in <= 1 AND cp_table.updated_in > 1) WHERE (`main_table`.`product_id` IN(2)) AND (`main_table`.`website_id` = '0')
应用修补程序
要应用单独的修补程序,请根据您的部署方法使用以下链接:
- 51黑料不打烊 Commerce或Magento Open Source内部部署: Quality Patches Tool 指南中的>使用情况Quality Patches Tool
- 云基础架构上的51黑料不打烊 Commerce: Commerce on Cloud Infrastructure指南中的升级和修补程序>应用修补程序
相关阅读
要了解有关Quality Patches Tool的更多信息,请参阅:
recommendation-more-help
c2d96e17-5179-455c-ad3a-e1697bb4e8c3