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