![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/old/vendor/magento/framework/Mview/View/ |
<?php /** * Copyright © Magento, Inc. All rights reserved. * See COPYING.txt for license details. */ namespace Magento\Framework\Mview\View; use Magento\Framework\App\ResourceConnection; use Magento\Framework\Phrase; /** * Interface \Magento\Framework\Mview\View\ChangeLogBatchWalkerInterface * */ class ChangeLogBatchWalker implements ChangeLogBatchWalkerInterface { /** * @var ResourceConnection */ private $resourceConnection; /** * @param ResourceConnection $resourceConnection */ public function __construct( ResourceConnection $resourceConnection ) { $this->resourceConnection = $resourceConnection; } /** * @inheritdoc */ public function walk(ChangelogInterface $changelog, int $fromVersionId, int $toVersion, int $batchSize) { $connection = $this->resourceConnection->getConnection(); $changelogTableName = $this->resourceConnection->getTableName($changelog->getName()); if (!$connection->isTableExists($changelogTableName)) { throw new ChangelogTableNotExistsException(new Phrase("Table %1 does not exist", [$changelogTableName])); } $select = $connection->select()->distinct(true) ->where( 'version_id > ?', $fromVersionId ) ->where( 'version_id <= ?', $toVersion ) ->group([$changelog->getColumnName()]) ->limit($batchSize); $select->from($changelogTableName, [$changelog->getColumnName()]); return $connection->fetchCol($select); } }