TYPO3 CMS  TYPO3_8-7
OptimizeDatabaseTableTask.php
Go to the documentation of this file.
1 <?php
3 
4 /*
5  * This file is part of the TYPO3 CMS project.
6  *
7  * It is free software; you can redistribute it and/or modify it under
8  * the terms of the GNU General Public License, either version 2
9  * of the License, or any later version.
10  *
11  * For the full copyright and license information, please read the
12  * LICENSE.txt file that was distributed with this source code.
13  *
14  * The TYPO3 project - inspiring people to share!
15  */
19 
28 {
35  public $selectedTables = [];
36 
42  public function execute()
43  {
44  $connectionPool = GeneralUtility::makeInstance(ConnectionPool::class);
45  foreach ($this->selectedTables as $tableName) {
46  $connection = $connectionPool->getConnectionForTable($tableName);
47 
48  if (strpos($connection->getServerVersion(), 'MySQL') === 0) {
49  try {
50  $connection->query('OPTIMIZE TABLE ' . $connection->quoteIdentifier($tableName));
51  } catch (DBALException $e) {
52  throw new \RuntimeException(
53  TableGarbageCollectionTask::class . ' failed for: ' . $tableName . ': ' .
54  $e->getPrevious()->getMessage(),
55  1441390263
56  );
57  }
58  }
59  }
60 
61  return true;
62  }
63 
69  public function getAdditionalInformation()
70  {
71  return implode(', ', $this->selectedTables);
72  }
73 }
static makeInstance($className,... $constructorArguments)