database compare removed keys -> will be implemented with SHOW KEYS

This commit is contained in:
OpenXE 2022-11-28 12:08:13 +00:00
parent e25ffdd1f1
commit 483a002014

View File

@ -112,7 +112,7 @@ if ($argc > 1) {
$clean = false; $clean = false;
} }
echo("--------------- Loading from database $schema@$host... ---------------\n"); echo("--------------- Loading from database '$schema@$host'... ---------------\n");
$tables = load_tables_from_db($host, $schema, $user, $passwd); $tables = load_tables_from_db($host, $schema, $user, $passwd);
if (empty($tables)) { if (empty($tables)) {
@ -120,7 +120,7 @@ if ($argc > 1) {
exit; exit;
} }
echo("--------------- Loading from database complete. ---------------\n"); echo("--------------- Loading from database '$schema@$host' complete. ---------------\n");
if ($export) { if ($export) {
@ -152,7 +152,7 @@ if ($argc > 1) {
// Do the comparison // Do the comparison
echo("--------------- Comparison Databse DB vs. CSV ---------------\n"); echo("--------------- Comparison Databse DB '$schema@$host' vs. CSV ---------------\n");
echo(count($tables)." tables in DB, ".count($compare_tables)." in CSV.\n"); echo(count($tables)." tables in DB, ".count($compare_tables)." in CSV.\n");
$compare_differences = compare_table_array($tables,"in DB",$compare_tables,"in CSV",false); $compare_differences = compare_table_array($tables,"in DB",$compare_tables,"in CSV",false);
@ -168,7 +168,8 @@ if ($argc > 1) {
echo("\n"); echo("\n");
} }
} }
echo("--------------- Comparison CSV vs. database ---------------\n");
echo("--------------- Comparison CSV vs. database '$schema@$host' ---------------\n");
$compare_differences = compare_table_array($compare_tables,"in CSV",$tables,"in DB",true); $compare_differences = compare_table_array($compare_tables,"in CSV",$tables,"in DB",true);
echo("Comparison found ".(empty($compare_differences)?0:count($compare_differences))." differences.\n"); echo("Comparison found ".(empty($compare_differences)?0:count($compare_differences))." differences.\n");
@ -188,7 +189,7 @@ if ($argc > 1) {
if ($upgrade) { if ($upgrade) {
// First create all tables that are missing in the db // First create all tables that are missing in the db
echo("--------------- Calculating database upgrade... ---------------\n"); echo("--------------- Calculating database upgrade for '$schema@$host'... ---------------\n");
$upgrade_sql = array(); $upgrade_sql = array();
@ -214,27 +215,12 @@ if ($argc > 1) {
$sql = ""; $sql = "";
$sql = "CREATE TABLE `".$table['name']."` ("; $sql = "CREATE TABLE `".$table['name']."` (";
$comma = ""; $comma = "";
$primary_keys = array();
$keys = array();
foreach ($table['columns'] as $column) { foreach ($table['columns'] as $column) {
$sql .= $comma.column_sql_definition($table_name, $column); $sql .= $comma.column_sql_definition($table_name, $column);
$comma = ","; $comma = ",";
if ($column['Key'] == 'PRI') {
$primary_keys[] = $column['Field'];
}
if ($column['Key'] == 'MUL') {
$keys[] = $column['Field'];
}
} }
if (!empty($primary_keys)) {
$sql .= ", PRIMARY KEY (".implode(",",$primary_keys).")";
}
if (!empty($keys)) {
$sql .= ", KEY (".implode("), KEY (",$keys).")";
}
$sql .= ");";
$upgrade_sql[] = $sql;
break; break;
default: default:
echo("Upgrade type '".$table['type']."' on table '".$table['name']."' not supported.\n"); echo("Upgrade type '".$table['type']."' on table '".$table['name']."' not supported.\n");
@ -259,14 +245,6 @@ if ($argc > 1) {
$sql .= column_sql_definition($table_name, $column); $sql .= column_sql_definition($table_name, $column);
$sql .= ";"; $sql .= ";";
$upgrade_sql[] = $sql; $upgrade_sql[] = $sql;
// KEYS
if ($column['Key'] == 'PRI') {
$sql = "ALTER TABLE `$table_name` ADD PRIMARY KEY ($column_name);"; // This will not work for composed primary keys...
}
if ($column['Key'] == 'MUL') {
$sql = "ALTER TABLE `$table_name` ADD KEY ($column_name);";
}
$upgrade_sql[] = $sql;
} }
else { else {
echo("Error column_key while creating column '$column_name' in table '".$table['name']."'\n"); echo("Error column_key while creating column '$column_name' in table '".$table['name']."'\n");
@ -290,18 +268,11 @@ if ($argc > 1) {
if ($column_key !== false) { if ($column_key !== false) {
$column = $table['columns'][$column_key]; $column = $table['columns'][$column_key];
$sql = "ALTER TABLE `$table_name` MODIFY COLUMN "; $sql = "ALTER TABLE `$table_name` MODIFY COLUMN ";
$sql .= column_sql_definition($table_name, $column); $sql .= column_sql_definition($table_name, $column);
$sql .= ";"; $sql .= ";";
$upgrade_sql[] = $sql; $upgrade_sql[] = $sql;
// KEYS
if ($column['Key'] == 'PRI') {
$sql = "ALTER TABLE `$table_name` ADD PRIMARY KEY ($column_name);"; // This will not work for composed primary keys...
}
if ($column['Key'] == 'MUL') {
$sql = "ALTER TABLE `$table_name` ADD KEY ($column_name);";
}
$upgrade_sql[] = $sql;
} }
else { else {
echo("Error column_key while modifying column '$column_name' in table '".$table['name']."'\n"); echo("Error column_key while modifying column '$column_name' in table '".$table['name']."'\n");
@ -334,7 +305,7 @@ if ($argc > 1) {
} }
echo(count($upgrade_sql)." upgrade statements\n"); echo(count($upgrade_sql)." upgrade statements\n");
echo("--------------- Database upgrade calculated (show SQL with -v). ---------------\n"); echo("--------------- Database upgrade calculated for '$schema@$host' (show SQL with -v). ---------------\n");
} }
echo("--------------- Done. ---------------\n"); echo("--------------- Done. ---------------\n");
@ -564,8 +535,9 @@ function compare_table_array(array $nominal, string $nominal_name, array $actual
$compare_difference['type'] = "Column definition"; $compare_difference['type'] = "Column definition";
$compare_difference['table'] = $database_table['name']; $compare_difference['table'] = $database_table['name'];
$compare_difference['column'] = $column['Field']; $compare_difference['column'] = $column['Field'];
$compare_difference[$nominal_name] = $key."=".$value; $compare_difference['property'] = $key;
$compare_difference[$actual_name] = $key."=".$found_column[$key]; $compare_difference[$nominal_name] = $value;
$compare_difference[$actual_name] = $found_column[$key];
$compare_differences[] = $compare_difference; $compare_differences[] = $compare_difference;
// } // }
} }
@ -601,42 +573,45 @@ function column_sql_definition(string $table_name, array $column) : string {
$mysql_default_values_without_quote = array('current_timestamp()'); $mysql_default_values_without_quote = array('current_timestamp()');
if ($column['Null'] == "NO") { if ($column['Null'] == "NO") {
$column['Null'] = "NOT"; // Idiotic... $column['Null'] = " NOT NULL"; // Idiotic...
} }
if ($column['Null'] == "YES") { if ($column['Null'] == "YES") {
$column['Null'] = ""; // Also Idiotic... $column['Null'] = " NULL"; // Also Idiotic...
} }
if ($column['Default'] != '') { if ($column['Default'] != '') {
// Check for MYSQL function call as default // Check for MYSQL function call as default
if (in_array(strtolower($column['Default']),$mysql_default_values_without_quote)) { if (in_array(strtolower($column['Default']),$mysql_default_values_without_quote)) {
$quote = ""; $quote = "";
} else { } else {
// Remove quotes if there are // Remove quotes if there are
$column['Default'] = trim($column['Default'],"'"); $column['Default'] = trim($column['Default'],"'");
$quote = "'"; $quote = "'";
} }
$column['Default'] = " DEFAULT $quote".$column['Default']."$quote"; $column['Default'] = " DEFAULT $quote".$column['Default']."$quote";
} }
if ($column['Extra'] != '') {
$column['Extral'] = " ".$column['Extra'];
}
if ($column['Collation'] != '') { if ($column['Collation'] != '') {
$column['Collation'] = " COLLATE ".$column['Collation']; $column['Collation'] = " COLLATE ".$column['Collation'];
} }
$sql = $sql =
"`".$column['Field']."` ". "`".$column['Field']."` ".
$column['Type']." ". $column['Type'].
$column['Null']." NULL ". $column['Null'].
$column['Default']." ". $column['Default'].
$column['Extra']." ". $column['Extra'].
$column['Collation']; $column['Collation'];
return($sql); return($sql);
} }
function info() { function info() {
echo("OpenXE database compare\n"); echo("OpenXE database compare\n");
echo("Copyright 2022 (c) OpenXE project\n"); echo("Copyright 2022 (c) OpenXE project\n");