mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-26 04:31:14 +01:00
database compare removed keys -> will be implemented with SHOW KEYS
This commit is contained in:
parent
e25ffdd1f1
commit
483a002014
@ -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");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user