mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-11 00:18:25 +01:00
* Backup: backup ascii columns as such, allways check and if necessary fix indexes on restore
This commit is contained in:
parent
dc696455cc
commit
81fe3b0472
@ -688,6 +688,10 @@ class db_backup
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// check if backup contained all indexes and create missing ones
|
||||||
|
$this->schema_proc->CheckCreateIndexes();
|
||||||
|
|
||||||
return $n;
|
return $n;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -149,16 +149,18 @@ class schema_proc
|
|||||||
/**
|
/**
|
||||||
* Check if the given $columns exist as index in the index array $indexes
|
* Check if the given $columns exist as index in the index array $indexes
|
||||||
*
|
*
|
||||||
* @param string/array $columns column-name as string or array of column-names plus optional options key
|
* @param string|array $columns column-name as string or array of column-names plus optional options key
|
||||||
* @param array $indexs array of indexes (column-name as string or array of column-names plus optional options key)
|
* @param array $indexs array of indexes (column-name as string or array of column-names plus optional options key)
|
||||||
|
* @param boolean $ignore_length_limit =false should we take lenght-limits of indexes into account or not
|
||||||
* @return boolean true if index over $columns exist in the $indexes array
|
* @return boolean true if index over $columns exist in the $indexes array
|
||||||
*/
|
*/
|
||||||
function _in_index($columns,$indexs)
|
function _in_index($columns, $indexs, $ignore_length_limit=false)
|
||||||
{
|
{
|
||||||
if (is_array($columns))
|
if (is_array($columns))
|
||||||
{
|
{
|
||||||
unset($columns['options']);
|
unset($columns['options']);
|
||||||
$columns = implode('-',$columns);
|
$columns = implode('-',$columns);
|
||||||
|
if ($ignore_length_limit) $columns = preg_replace('/\(\d+\)/', '', $columns);
|
||||||
}
|
}
|
||||||
foreach($indexs as $index)
|
foreach($indexs as $index)
|
||||||
{
|
{
|
||||||
@ -167,6 +169,7 @@ class schema_proc
|
|||||||
unset($index['options']);
|
unset($index['options']);
|
||||||
$index = implode('-',$index);
|
$index = implode('-',$index);
|
||||||
}
|
}
|
||||||
|
if ($ignore_length_limit) $index = preg_replace('/\(\d+\)/', '', $index);
|
||||||
if ($columns == $index) return true;
|
if ($columns == $index) return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
@ -549,13 +552,13 @@ class schema_proc
|
|||||||
|
|
||||||
$aSql = $this->dict->CreateIndexSQL($sIdxName,$sTableName,$aColumnNames,$options);
|
$aSql = $this->dict->CreateIndexSQL($sIdxName,$sTableName,$aColumnNames,$options);
|
||||||
|
|
||||||
return $this->ExecuteSQLArray($aSql,2,'CreateIndexSQL(%1,%2,%3,%4) sql=%5',False,$name,$sTableName,$aColumnNames,$options,$aSql);
|
return $this->ExecuteSQLArray($aSql,2,'CreateIndexSQL(%1,%2,%3,%4) sql=%5',False,$sTableName,$aColumnNames,$options,$sIdxName,$aSql);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Drop an Index
|
* Drop an Index
|
||||||
*
|
*
|
||||||
* @param string $sTablename table-name
|
* @param string $sTableName table-name
|
||||||
* @param array/string $aColumnNames columns of the index or the name of the index
|
* @param array/string $aColumnNames columns of the index or the name of the index
|
||||||
* @return int 2: no error, 1: errors, but continued, 0: errors aborted
|
* @return int 2: no error, 1: errors, but continued, 0: errors aborted
|
||||||
*/
|
*/
|
||||||
@ -1246,7 +1249,9 @@ class schema_proc
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'C': case 'C2':
|
case 'C': case 'C2':
|
||||||
$definition['fd'][$name]['type'] = 'varchar';
|
// ascii columns are reported as varchar
|
||||||
|
$definition['fd'][$name]['type'] = $this->m_odb->get_column_attribute($name, $sTableName, true, 'type') === 'ascii' ?
|
||||||
|
'ascii' : 'varchar';
|
||||||
$definition['fd'][$name]['precision'] = $column->max_length;
|
$definition['fd'][$name]['precision'] = $column->max_length;
|
||||||
break;
|
break;
|
||||||
case 'B':
|
case 'B':
|
||||||
@ -1368,7 +1373,7 @@ class schema_proc
|
|||||||
if (method_exists($this->dict,'MetaIndexes') &&
|
if (method_exists($this->dict,'MetaIndexes') &&
|
||||||
is_array($indexes = $this->dict->MetaIndexes($sTableName)) && count($indexes))
|
is_array($indexes = $this->dict->MetaIndexes($sTableName)) && count($indexes))
|
||||||
{
|
{
|
||||||
foreach($indexes as $index_name => $index)
|
foreach($indexes as $index)
|
||||||
{
|
{
|
||||||
if($this->capabilities['name_case'] == 'upper')
|
if($this->capabilities['name_case'] == 'upper')
|
||||||
{
|
{
|
||||||
@ -1381,13 +1386,55 @@ class schema_proc
|
|||||||
}
|
}
|
||||||
$kind = $index['unique'] ? 'uc' : 'ix';
|
$kind = $index['unique'] ? 'uc' : 'ix';
|
||||||
|
|
||||||
$definition[$kind][$index_name] = count($index['columns']) > 1 ? $index['columns'] : $index['columns'][0];
|
$definition[$kind][] = count($index['columns']) > 1 ? $index['columns'] : $index['columns'][0];
|
||||||
}
|
}
|
||||||
if ($this->debug > 2) $this->debug_message("schema_proc::GetTableDefintion: MetaIndexes(%1) = %2",False,$sTableName,$indexes);
|
if ($this->debug > 2) $this->debug_message("schema_proc::GetTableDefintion: MetaIndexes(%1) = %2",False,$sTableName,$indexes);
|
||||||
}
|
}
|
||||||
return $definition;
|
return $definition;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if all indexes exist and create them if not
|
||||||
|
*
|
||||||
|
* Does not check index-type of length!
|
||||||
|
*/
|
||||||
|
function CheckCreateIndexes()
|
||||||
|
{
|
||||||
|
foreach($this->adodb->MetaTables('TABLES') as $table)
|
||||||
|
{
|
||||||
|
if (!($table_def = $this->m_odb->get_table_definitions(true, $table))) continue;
|
||||||
|
|
||||||
|
$definition = array();
|
||||||
|
$this->GetIndexes($table, $definition);
|
||||||
|
|
||||||
|
// iterate though indexes we should have according to tables_current
|
||||||
|
foreach(array('uc', 'ix') as $type)
|
||||||
|
{
|
||||||
|
foreach($table_def[$type] as $columns)
|
||||||
|
{
|
||||||
|
// sometimes primary key is listed as (unique) index too --> ignore it
|
||||||
|
if ($this->_in_index($columns, array($table_def['pk']), true)) continue;
|
||||||
|
|
||||||
|
// check if they exist in real table and create them if not
|
||||||
|
if (!$this->_in_index($columns, $definition[$type]) &&
|
||||||
|
// sometimes index is listed as unique index too --> ignore that
|
||||||
|
($type == 'uc' || !$this->_in_index($columns, $definition['uc'], true)))
|
||||||
|
{
|
||||||
|
// check if index may exists, but without limit in column-name
|
||||||
|
if ($this->_in_index($columns, $definition[$type], true))
|
||||||
|
{
|
||||||
|
// for PostgreSQL we dont use length-limited indexes --> nothing to do
|
||||||
|
if ($this->m_odb->Type == 'pgsql') continue;
|
||||||
|
// for MySQL we drop current index and create it with correct length
|
||||||
|
$this->DropIndex($table, $definition);
|
||||||
|
}
|
||||||
|
$this->CreateIndex($table, $columns, $type == 'uc');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get actual columnnames as a comma-separated string in $sColumns and set indices as class-vars pk,fk,ix,uc
|
* Get actual columnnames as a comma-separated string in $sColumns and set indices as class-vars pk,fk,ix,uc
|
||||||
*
|
*
|
||||||
|
Loading…
Reference in New Issue
Block a user