![]() 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/setup/src/Magento/Setup/Model/FixtureGenerator/ |
<?php /** * Copyright © Magento, Inc. All rights reserved. * See COPYING.txt for license details. */ namespace Magento\Setup\Model\FixtureGenerator; use Magento\Framework\App\ResourceConnection; use Magento\Framework\DB\Profiler; /** * Collect insert queries for quick entity generation */ class SqlCollector { /** * @var ResourceConnection */ private $resourceConnection; /** * @var array */ private $sql = []; /** * @var \Zend_Db_Profiler */ private $profiler; /** * @param ResourceConnection $resourceConnection */ public function __construct(ResourceConnection $resourceConnection) { $this->resourceConnection = $resourceConnection; } /** * @param string $sql * @param array $bind * @return void */ private function addSql($sql, $bind) { preg_match('~(?:INSERT|REPLACE)\s+(?:IGNORE)?\s*INTO `(.*)` \((.*)\) VALUES (\(.*\))+~', $sql, $queryMatches); if ($queryMatches) { $table = $queryMatches[1]; $fields = preg_replace('~[\s+`]+~', '', $queryMatches[2]); $fields = $fields ? explode(',', $fields) : []; $sqlBindGroupAmount = count(explode('), (', $queryMatches[3])); preg_match(' ~\((.*?)\)~', $queryMatches[3], $sqlBind); $sqlBind = preg_replace(['~,\s*~', '~\'~'], [',', ''], $sqlBind[1]); $sqlBind = $sqlBind ? explode(',', $sqlBind) : []; $binds = []; // process multi queries if ($sqlBindGroupAmount > 1) { $valuesCount = count($bind)/$sqlBindGroupAmount; for ($i = 0; $i < $sqlBindGroupAmount; $i++) { $binds[] = array_combine( $fields, $this->handleBindValues($sqlBind, $bind, $i * $valuesCount) ); } } else { $sqlBind = $this->handleBindValues($sqlBind, $bind); $binds[] = array_combine($fields, $sqlBind); } $this->sql[] = [$binds, $table]; } } /** * @param array $sqlBind * @param array $bind * @param int $bindPosition * @return array */ private function handleBindValues(array $sqlBind, array $bind, $bindPosition = 0) { $bind = array_values($bind); foreach ($sqlBind as $i => $fieldValue) { if ($fieldValue === '?') { $sqlBind[$i] = $bind[$bindPosition]; $bindPosition++; } } return $sqlBind; } /** * @return array */ public function getSql() { return $this->sql; } /** * Enable sql parsing * * @return void */ public function enable() { $this->sql = []; $this->getProfiler()->clear(); $this->getProfiler()->setEnabled(true); } /** * Disable sql parsing and collect all queries from profiler * * @return void */ public function disable() { $this->getProfiler()->setEnabled(false); $queries = $this->getProfiler()->getQueryProfiles() ?: []; foreach ($queries as $query) { if ($query->getQueryType() === Profiler::INSERT || $this->isReplaceQuery($query)) { // For generator we do not care about REPLACE query and can use INSERT instead // due to it's not support parallel execution $this->addSql($query->getQuery(), $query->getQueryParams()); } } } /** * Detect "REPLACE INTO ..." query. * * @param Profiler $query * @return bool */ private function isReplaceQuery($query) { return $query->getQueryType() === Profiler::QUERY && 0 === stripos(ltrim($query->getQuery()), 'replace'); } /** * @return \Zend_Db_Profiler */ private function getProfiler() { if ($this->profiler === null) { $this->profiler = $this->resourceConnection->getConnection()->getProfiler(); } return $this->profiler; } }