set() * @param array $params */ public function __construct($params = array()) { $this->set($params); } static public function singleton($schema, $table, $index_name = '') { PMA_Index::_loadIndexes($table, $schema); if (! isset(PMA_Index::$_registry[$schema][$table][$index_name])) { $index = new PMA_Index; if (strlen($index_name)) { $index->setName($index_name); PMA_Index::$_registry[$schema][$table][$index->getName()] = $index; } return $index; } else { return PMA_Index::$_registry[$schema][$table][$index_name]; } } /** * returns an array with all indexes from the given table * * @uses PMA_Index::_loadIndexes() * @uses PMA_Index::$_registry * @param string $table * @param string $schema * @return array */ static public function getFromTable($table, $schema) { PMA_Index::_loadIndexes($table, $schema); if (isset(PMA_Index::$_registry[$schema][$table])) { return PMA_Index::$_registry[$schema][$table]; } else { return array(); } } /** * return primary if set, false otherwise * * @uses PMA_Index::_loadIndexes() * @uses PMA_Index::$_registry * @param string $table * @param string $schema * @return mixed primary index or false if no one exists */ static public function getPrimary($table, $schema) { PMA_Index::_loadIndexes($table, $schema); if (isset(PMA_Index::$_registry[$schema][$table]['PRIMARY'])) { return PMA_Index::$_registry[$schema][$table]['PRIMARY']; } else { return false; } } /** * Load index data for table * * @uses PMA_Index::$_registry * @uses PMA_DBI_fetch_result() * @uses PMA_backquote() * @uses PMA_Index * @uses PMA_Index->addColumn() * @param string $table * @param string $schema * @return boolean */ static protected function _loadIndexes($table, $schema) { if (isset(PMA_Index::$_registry[$schema][$table])) { return true; } $_raw_indexes = PMA_DBI_fetch_result('SHOW INDEX FROM ' . PMA_backquote($schema) . '.' . PMA_backquote($table)); foreach ($_raw_indexes as $_each_index) { $_each_index['Schema'] = $schema; if (! isset(PMA_Index::$_registry[$schema][$table][$_each_index['Key_name']])) { $key = new PMA_Index($_each_index); PMA_Index::$_registry[$schema][$table][$_each_index['Key_name']] = $key; } else { $key = PMA_Index::$_registry[$schema][$table][$_each_index['Key_name']]; } $key->addColumn($_each_index); } return true; } /** * Add column to index * * @uses $this->_columns * @uses PMA_Index_Column * @param array $params column params */ public function addColumn($params) { if (strlen($params['Column_name'])) { $this->_columns[$params['Column_name']] = new PMA_Index_Column($params); } } public function addColumns($columns) { $_columns = array(); if (isset($columns['names'])) { // coming from form // $columns[names][] // $columns[sub_parts][] foreach ($columns['names'] as $key => $name) { $_columns[] = array( 'Column_name' => $name, 'Sub_part' => $columns['sub_parts'][$key], ); } } else { // coming from SHOW INDEXES // $columns[][name] // $columns[][sub_part] // ... $_columns = $columns; } foreach ($_columns as $column) { $this->addColumn($column); } } /** * Returns true if $column indexed in this index * * @uses $this->_columns * @param string $column * @return boolean */ public function hasColumn($column) { return isset($this->_columns[$column]); } public function set($params) { if (isset($params['columns'])) { $this->addColumns($params['columns']); } if (isset($params['Schema'])) { $this->_schema = $params['Schema']; } if (isset($params['Table'])) { $this->_table = $params['Table']; } if (isset($params['Key_name'])) { $this->_name = $params['Key_name']; } if (isset($params['Index_type'])) { $this->_type = $params['Index_type']; } if (isset($params['Comment'])) { $this->_remarks = $params['Comment']; } if (isset($params['Index_comment'])) { $this->_comment = $params['Index_comment']; } if (isset($params['Non_unique'])) { $this->_non_unique = $params['Non_unique']; } if (isset($params['Packed'])) { $this->_packed = $params['Packed']; } if ('PRIMARY' == $this->_name) { $this->_choice = 'PRIMARY'; } elseif ('FULLTEXT' == $this->_type) { $this->_choice = 'FULLTEXT'; } elseif ('0' == $this->_non_unique) { $this->_choice = 'UNIQUE'; } else { $this->_choice = 'INDEX'; } } public function getColumnCount() { return count($this->_columns); } public function getComment() { return $this->_comment; } public function getRemarks() { return $this->_remarks; } public function getComments() { $comments = $this->getRemarks(); if (strlen($comments)) { $comments .= "\n"; } $comments .= $this->getComment(); return $comments; } public function getType() { return $this->_type; } /** * Return a list of all index choices * * @return array index choices */ static public function getIndexChoices() { return array( 'PRIMARY', 'INDEX', 'UNIQUE', 'FULLTEXT', ); } public function generateIndexSelector() { $html_options = ''; foreach (PMA_Index::getIndexChoices() as $each_index_choice) { if ($each_index_choice === 'PRIMARY' && $this->_choice !== 'PRIMARY' && PMA_Index::getPrimary($this->_table, $this->_schema)) { // skip PRIMARY if there is already one in the table continue; } $html_options .= '' . "\n"; } return $html_options; } public function getPacked() { return $this->_packed; } public function isPacked($as_text = false) { if ($as_text) { $r = array( '0' => $GLOBALS['strNo'], '1' => $GLOBALS['strYes'], ); } else { $r = array( '0' => false, '1' => true, ); } if (null === $this->_packed) { return $r[0]; } return $this->_packed; } public function getNonUnique() { return $this->_non_unique; } public function isUnique($as_text = false) { if ($as_text) { $r = array( '0' => $GLOBALS['strYes'], '1' => $GLOBALS['strNo'], ); } else { $r = array( '0' => true, '1' => false, ); } return $r[$this->_non_unique]; } public function getName() { return $this->_name; } public function setName($name) { $this->_name = (string) $name; } public function getColumns() { return $this->_columns; } /** * Show index data * * @param string $table The tablename * @param array $indexes_info Referenced info array * @param array $indexes_data Referenced data array * @param boolean $print_mode * @access public * @return array Index collection array * @author Garvin Hicking (pma@supergarv.de) */ static public function getView($table, $schema, $print_mode = false) { $indexes = PMA_Index::getFromTable($table, $schema); if (count($indexes) < 1) { return PMA_Message::warning('strNoIndex')->getDisplay(); } $r = ''; $r .= '
' . $GLOBALS['strAction'] . ' | '; } $r .= '' . $GLOBALS['strKeyname'] . ' | '; $r .= '' . $GLOBALS['strType'] . ' | '; $r .= '' . $GLOBALS['strUnique'] . ' | '; $r .= '' . $GLOBALS['strPacked'] . ' | '; $r .= '' . $GLOBALS['strField'] . ' | '; $r .= '' . $GLOBALS['strCardinality'] . ' | '; $r .= '' . $GLOBALS['strCollation'] . ' | '; $r .= '' . $GLOBALS['strNull'] . ' | '; $r .= '' . $GLOBALS['strComment'] . ' | '; $r .= '|
---|---|---|---|---|---|---|---|---|---|---|
' . ' ' . PMA_getIcon('b_edit.png', $GLOBALS['strEdit']) . '' . ' | ' . "\n"; $this_params = $GLOBALS['url_params']; if ($index->getName() == 'PRIMARY') { $this_params['sql_query'] = 'ALTER TABLE ' . PMA_backquote($table) . ' DROP PRIMARY KEY'; $this_params['zero_rows'] = $GLOBALS['strPrimaryKeyHasBeenDropped']; $js_msg = PMA_jsFormat('ALTER TABLE ' . $table . ' DROP PRIMARY KEY'); } else { $this_params['sql_query'] = 'ALTER TABLE ' . PMA_backquote($table) . ' DROP INDEX ' . PMA_backquote($index->getName()); $this_params['zero_rows'] = sprintf($GLOBALS['strIndexHasBeenDropped'], $index->getName()); $js_msg = PMA_jsFormat('ALTER TABLE ' . $table . ' DROP INDEX ' . $index->getName()); } $r .= '' . ' ' . PMA_getIcon('b_drop.png', $GLOBALS['strDrop']) . '' . ' | ' . "\n"; } $r .= '' . htmlspecialchars($index->getName()) . ' | '; $r .= '' . htmlspecialchars($index->getType()) . ' | '; $r .= '' . $index->isUnique(true) . ' | '; $r .= '' . $index->isPacked(true) . ' | '; foreach ($index->getColumns() as $column) { if ($column->getSeqInIndex() > 1) { $r .= '|||||
' . htmlspecialchars($column->getName()); if ($column->getSubPart()) { $r .= ' (' . $column->getSubPart() . ')'; } $r .= ' | '; $r .= '' . htmlspecialchars($column->getCardinality()) . ' | '; $r .= '' . htmlspecialchars($column->getCollation()) . ' | '; $r .= '' . htmlspecialchars($column->getNull()) . ' | '; if ($column->getSeqInIndex() == 1) { $r .= '' . htmlspecialchars($index->getComments()) . ' | '; } $r .= '