Update website
This commit is contained in:
parent
a0b0d3dae7
commit
ae7ef6ad45
3151 changed files with 566766 additions and 48 deletions
177
admin/phpMyAdmin/libraries/classes/IndexColumn.php
Normal file
177
admin/phpMyAdmin/libraries/classes/IndexColumn.php
Normal file
|
@ -0,0 +1,177 @@
|
|||
<?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,
|
||||
];
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue