getType()) { case 'PRIMARY': if ($index->getName() == '') { $index->setName('PRIMARY'); } elseif ($index->getName() != 'PRIMARY') { $error = PMA_Message::error('strPrimaryKeyName'); } $sql_query .= ' ADD PRIMARY KEY'; break; case 'FULLTEXT': case 'UNIQUE': case 'INDEX': if ($index->getName() == 'PRIMARY') { $error = PMA_Message::error('strCantRenameIdxToPrimary'); } $sql_query .= ' ADD ' . $index->getType() . ' ' . ($index->getName() ? PMA_backquote($index->getName()) : ''); break; } // end switch $index_fields = array(); foreach ($index->getColumns() as $key => $column) { $index_fields[$key] = PMA_backquote($column->getName()); if ($column->getSubPart()) { $index_fields[$key] .= '(' . $column->getSubPart() . ')'; } } // end while if (empty($index_fields)){ $error = PMA_Message::error('strNoIndexPartsDefined'); } else { $sql_query .= ' (' . implode(', ', $index_fields) . ')'; } if (! $error) { PMA_DBI_query($sql_query); $message = PMA_Message::success('strTableAlteredSuccessfully'); $message->addParam($table); $active_page = 'tbl_structure.php'; require './tbl_structure.php'; exit; } else { $error->display(); } } // end builds the new index /** * Display the form to edit/create an index */ // Displays headers (if needed) $GLOBALS['js_include'][] = 'functions.js'; $GLOBALS['js_include'][] = 'indexes.js'; require_once './libraries/tbl_info.inc.php'; require_once './libraries/tbl_links.inc.php'; if (isset($_REQUEST['index']) && is_array($_REQUEST['index'])) { // coming already from form $add_fields = count($_REQUEST['index']['columns']['names']) - $index->getColumnCount(); if (isset($_REQUEST['add_fields'])) { $add_fields += $_REQUEST['added_fields']; } } elseif (isset($_REQUEST['create_index'])) { $add_fields = $_REQUEST['added_fields']; } else { $add_fields = 1; } // end preparing form values ?>