git-svn-id: https://adminer.svn.sourceforge.net/svnroot/adminer/trunk@18 7c3ca157-0c34-0410-bff1-cbf682f78f5c
93 lines
4.6 KiB
PHP
93 lines
4.6 KiB
PHP
<?php
|
|
$types = array("int"); //!
|
|
if ($_POST) {
|
|
if ($_POST["drop"]) {
|
|
$query = "DROP TABLE " . idf_escape($_GET["create"]);
|
|
$message = lang('Table has been dropped.');
|
|
} else {
|
|
$fields = array();
|
|
ksort($_POST["fields"]);
|
|
foreach ($_POST["fields"] as $key => $field) {
|
|
if (strlen($field["name"]) && in_array($field["type"], $types)) {
|
|
$length = ($field["length"] ? "(" . intval($field["length"]) . ")" : ""); //! decimal, enum and set lengths
|
|
$fields[] = idf_escape($field["name"]) . " " . $field["type"] . $length . ($field["not_null"] ? " NOT NULL" : "") . ($field["auto_increment"] ? " AUTO_INCREMENT" : "");
|
|
}
|
|
}
|
|
$status = ($_POST["Engine"] ? " ENGINE='" . mysql_real_escape_string($_POST["Engine"]) . "'" : "") . ($_POST["Collation"] ? " COLLATE '" . mysql_real_escape_string($_POST["Collation"]) . "'" : "");
|
|
if (strlen($_GET["create"])) {
|
|
$query = "ALTER TABLE " . idf_escape($_GET["create"]) . " RENAME TO " . idf_escape($_POST["name"]) . ", $status";
|
|
$message = lang('Table has been altered.');
|
|
} else {
|
|
$query = "CREATE TABLE " . idf_escape($_POST["name"]) . " (" . implode(", ", $fields) . ")$status";
|
|
$message = lang('Table has been created.');
|
|
}
|
|
}
|
|
if (mysql_query($query)) {
|
|
redirect(($_POST["drop"] ? substr($SELF, 0, -1) : $SELF . "table=" . urlencode($_POST["name"])), $message);
|
|
}
|
|
$error = mysql_error();
|
|
}
|
|
page_header(strlen($_GET["create"]) ? lang('Alter table') . ': ' . htmlspecialchars($_GET["create"]) : lang('Create table'));
|
|
echo "<h2>" . (strlen($_GET["create"]) ? lang('Alter table') . ': ' . htmlspecialchars($_GET["create"]) : lang('Create table')) . "</h2>\n";
|
|
|
|
if ($_POST) {
|
|
echo "<p class='error'>" . lang('Unable to operate table') . ": " . htmlspecialchars($error) . "</p>\n";
|
|
$row = $_POST;
|
|
} elseif (strlen($_GET["create"])) {
|
|
$row = mysql_fetch_assoc(mysql_query("SHOW TABLE STATUS LIKE '" . mysql_real_escape_string($_GET["create"]) . "'"));
|
|
$row["name"] = $_GET["create"];
|
|
$row["fields"] = array();
|
|
$result1 = mysql_query("SHOW COLUMNS FROM " . idf_escape($_GET["create"]));
|
|
while ($row1 = mysql_fetch_assoc($result1)) {
|
|
if (preg_match('~^([^)]*)\\((.*)\\)$~', $row1["Type"], $match)) {
|
|
$row1["Type"] = $match[1];
|
|
$row1["Length"] = $match[2];
|
|
}
|
|
$row["fields"][] = $row1;
|
|
}
|
|
mysql_free_result($result1);
|
|
} else {
|
|
$row = array("fields" => array());
|
|
}
|
|
//! collate columns, references, indexes, unsigned, default
|
|
?>
|
|
<form action="" method="post">
|
|
<p>
|
|
<?php echo lang('Table name'); ?>: <input name="name" maxlength="64" value="<?php echo htmlspecialchars($row["name"]); ?>" />
|
|
<select name="Engine"><option value="">(<?php echo lang('engine'); ?>)</option><?php echo optionlist(engines(), $row["Engine"], "not_vals"); ?></select>
|
|
<select name="Collation"><option value="">(<?php echo lang('collation'); ?>)</option><?php echo optionlist(collations(), $row["Collation"], "not_vals"); ?></select>
|
|
</p>
|
|
<table border="0" cellspacing="0" cellpadding="2">
|
|
<thead><tr><th><?php echo lang('Name'); ?></th><td><?php echo lang('Type'); ?></td><td><?php echo lang('Length'); ?></td><td><?php echo lang('NULL'); ?></td><td><?php echo lang('Auto-increment'); ?></td></tr></thead>
|
|
<?php
|
|
$i=-1;
|
|
foreach ($row["fields"] as $i => $field) {
|
|
if (strlen($field["Field"])) {
|
|
?>
|
|
<tr>
|
|
<th><input name="fields[<?php echo $i; ?>][Field]" value="<?php echo htmlspecialchars($field["Field"]); ?>" maxlength="64" /></th>
|
|
<td><select name="fields[<?php echo $i; ?>][Type]"><?php echo optionlist($types, $field["Type"], "not_vals"); ?></select></td>
|
|
<td><input name="fields[<?php echo $i; ?>][Length]" value="<?php echo htmlspecialchars($field["Length"]); ?>" size="3" /></td>
|
|
<td><input type="checkbox" name="fields[<?php echo $i; ?>][Null]" value="YES"<?php if ($field["Null"] == "YES") { ?> checked="checked"<?php } ?> /></td>
|
|
<td><input type="checkbox" name="fields[<?php echo $i; ?>][Extra]" value="auto_increment"<?php if ($field["Extra"] == "auto_increment") { ?> checked="checked"<?php } ?> /></td>
|
|
</tr>
|
|
<?php
|
|
}
|
|
}
|
|
$i++;
|
|
//! JavaScript for next rows
|
|
?>
|
|
<tr>
|
|
<th><input name="fields[<?php echo $i; ?>][Field]" maxlength="64" /></th>
|
|
<td><select name="fields[<?php echo $i; ?>][Type]"><?php echo optionlist($types, array(), "not_vals"); ?></select></td>
|
|
<td><input name="fields[<?php echo $i; ?>][Length]" size="3" /></td>
|
|
<td><input type="checkbox" name="fields[<?php echo $i; ?>][Null]" value="YES" /></td>
|
|
<td><input type="checkbox" name="fields[<?php echo $i; ?>][Extra]" value="auto_increment" /></td>
|
|
</tr>
|
|
</table>
|
|
<p>
|
|
<input type="submit" value="<?php echo lang('Save'); ?>" />
|
|
<?php if (strlen($_GET["create"])) { ?><input type="submit" name="drop" value="<?php echo lang('Drop'); ?>" /><?php } ?>
|
|
</p>
|
|
</form>
|