123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142 |
- <?php
- declare(strict_types=1);
- namespace PhpMyAdmin\Table;
- use PhpMyAdmin\DatabaseInterface;
- use PhpMyAdmin\Index;
- use PhpMyAdmin\Util;
- use function implode;
- use function sprintf;
- final class Maintenance
- {
- /** @var DatabaseInterface */
- private $dbi;
- public function __construct(DatabaseInterface $dbi)
- {
- $this->dbi = $dbi;
- }
- /**
- * @param string[] $tables
- *
- * @return array
- */
- public function getAnalyzeTableRows(string $db, array $tables): array
- {
- $backQuotedTables = Util::backquote($tables);
- $query = 'ANALYZE TABLE ' . implode(', ', $backQuotedTables) . ';';
- $this->dbi->selectDb($db);
- $result = $this->dbi->fetchResult($query);
- $rows = [];
- foreach ($result as $row) {
- $rows[$row['Table']][] = $row;
- }
- return [$rows, $query];
- }
- /**
- * @param string[] $tables
- *
- * @return array
- */
- public function getCheckTableRows(string $db, array $tables): array
- {
- $backQuotedTables = Util::backquote($tables);
- $query = 'CHECK TABLE ' . implode(', ', $backQuotedTables) . ';';
- $this->dbi->selectDb($db);
- $result = $this->dbi->fetchResult($query);
- $rows = [];
- foreach ($result as $row) {
- $rows[$row['Table']][] = $row;
- }
- return [$rows, $query];
- }
- /**
- * @param string[] $tables
- *
- * @return array
- */
- public function getChecksumTableRows(string $db, array $tables): array
- {
- $backQuotedTables = Util::backquote($tables);
- $query = 'CHECKSUM TABLE ' . implode(', ', $backQuotedTables) . ';';
- $this->dbi->selectDb($db);
- $rows = $this->dbi->fetchResult($query);
- $warnings = $this->dbi->getWarnings();
- return [$rows, $query, $warnings];
- }
- /** @param string[] $tables */
- public function getIndexesProblems(string $db, array $tables): string
- {
- $indexesProblems = '';
- foreach ($tables as $table) {
- $check = Index::findDuplicates($table, $db);
- if (empty($check)) {
- continue;
- }
- $indexesProblems .= sprintf(__('Problems with indexes of table `%s`'), $table);
- $indexesProblems .= $check;
- }
- return $indexesProblems;
- }
- /**
- * @param string[] $tables
- *
- * @return array
- */
- public function getOptimizeTableRows(string $db, array $tables): array
- {
- $backQuotedTables = Util::backquote($tables);
- $query = 'OPTIMIZE TABLE ' . implode(', ', $backQuotedTables) . ';';
- $this->dbi->selectDb($db);
- $result = $this->dbi->fetchResult($query);
- $rows = [];
- foreach ($result as $row) {
- $rows[$row['Table']][] = $row;
- }
- return [$rows, $query];
- }
- /**
- * @param string[] $tables
- *
- * @return array
- */
- public function getRepairTableRows(string $db, array $tables): array
- {
- $backQuotedTables = Util::backquote($tables);
- $query = 'REPAIR TABLE ' . implode(', ', $backQuotedTables) . ';';
- $this->dbi->selectDb($db);
- $result = $this->dbi->fetchResult($query);
- $rows = [];
- foreach ($result as $row) {
- $rows[$row['Table']][] = $row;
- }
- return [$rows, $query];
- }
- }
|