123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177 |
- <?php
- declare(strict_types=1);
- namespace PhpMyAdmin;
- /**
- * Index column wrapper
- */
- class IndexColumn
- {
- /** @var string The column name */
- private $name = '';
- /** @var int The column sequence number in the index, starting with 1. */
- private $seqInIndex = 1;
- /**
- * @var string How the column is sorted in the index. "A" (Ascending) or
- * NULL (Not sorted)
- */
- private $collation = null;
- /**
- * The number of indexed characters if the column is only partly indexed,
- * NULL if the entire column is indexed.
- *
- * @var int
- */
- private $subPart = null;
- /**
- * Contains YES if the column may contain NULL.
- * If not, the column contains NO.
- *
- * @var string
- */
- private $null = '';
- /**
- * An estimate of the number of unique values in the index. This is updated
- * by running ANALYZE TABLE or myisamchk -a. Cardinality is counted based on
- * statistics stored as integers, so the value is not necessarily exact even
- * for small tables. The higher the cardinality, the greater the chance that
- * MySQL uses the index when doing joins.
- *
- * @var int
- */
- private $cardinality = null;
- /**
- * @param array $params an array containing the parameters of the index column
- */
- public function __construct(array $params = [])
- {
- $this->set($params);
- }
- /**
- * Sets parameters of the index column
- *
- * @param array $params an array containing the parameters of the index column
- *
- * @return void
- */
- public function set(array $params)
- {
- if (isset($params['Column_name'])) {
- $this->name = $params['Column_name'];
- }
- if (isset($params['Seq_in_index'])) {
- $this->seqInIndex = $params['Seq_in_index'];
- }
- if (isset($params['Collation'])) {
- $this->collation = $params['Collation'];
- }
- if (isset($params['Cardinality'])) {
- $this->cardinality = $params['Cardinality'];
- }
- if (isset($params['Sub_part'])) {
- $this->subPart = $params['Sub_part'];
- }
- if (! isset($params['Null'])) {
- return;
- }
- $this->null = $params['Null'];
- }
- /**
- * Returns the column name
- *
- * @return string column name
- */
- public function getName()
- {
- return $this->name;
- }
- /**
- * Return the column collation
- *
- * @return string column collation
- */
- public function getCollation()
- {
- return $this->collation;
- }
- /**
- * Returns the cardinality of the column
- *
- * @return int cardinality of the column
- */
- public function getCardinality()
- {
- return $this->cardinality;
- }
- /**
- * Returns whether the column is nullable
- *
- * @param bool $as_text whether to returned the string representation
- *
- * @return string nullability of the column. True/false or Yes/No depending
- * on the value of the $as_text parameter
- */
- public function getNull($as_text = false): string
- {
- if ($as_text) {
- if (! $this->null || $this->null === 'NO') {
- return __('No');
- }
- return __('Yes');
- }
- return $this->null;
- }
- /**
- * Returns the sequence number of the column in the index
- *
- * @return int sequence number of the column in the index
- */
- public function getSeqInIndex()
- {
- return $this->seqInIndex;
- }
- /**
- * Returns the number of indexed characters if the column is only
- * partly indexed
- *
- * @return int the number of indexed characters
- */
- public function getSubPart()
- {
- return $this->subPart;
- }
- /**
- * Gets the properties in an array for comparison purposes
- *
- * @return array an array containing the properties of the index column
- */
- public function getCompareData()
- {
- return [
- 'Column_name' => $this->name,
- 'Seq_in_index' => $this->seqInIndex,
- 'Collation' => $this->collation,
- 'Sub_part' => $this->subPart,
- 'Null' => $this->null,
- ];
- }
- }
|