0)
	{
		$SQL_ARRAY=file($sf);
	}
}
function WriteSQL()
{
	global $SQL_ARRAY,$config;
	$sf=$config['paths']['config'] . 'sql_statements';
	$str="";
	for ($i=0; $i < count($SQL_ARRAY); $i++)
	{
		$str.=$SQL_ARRAY[$i];
		if (substr($str,-1) != "\n" && $i != ( count($SQL_ARRAY) - 1 )) $str.="\n";
	}
	if ($config['magic_quotes_gpc']) $str=stripslashes($str);
	$fp=fopen($sf,"wb");
	fwrite($fp,$str);
	fclose($fp);
}
function SQL_Name($index)
{
	global $SQL_ARRAY;
	$s=explode('|',$SQL_ARRAY[$index]);
	return $s[0];
}
function SQL_String($index)
{
	global $SQL_ARRAY;
	if (isset($SQL_ARRAY[$index]) && !empty($SQL_ARRAY[$index]))
	{
		$s=explode('|',$SQL_ARRAY[$index],2);
		return ( isset($s[1]) ) ? $s[1] : '';
	}
}
function SQL_ComboBox()
{
	global $SQL_ARRAY,$tablename,$nl;
	$s='';
	if (count($SQL_ARRAY) > 0)
	{
		$s=$nl . $nl . '' . $nl;
		$s.='--- ' . $nl;
		for ($i=0; $i < count($SQL_ARRAY); $i++)
		{
			$s.='' . SQL_Name($i) . ' ' . $nl;
		}
		$s.=' ' . $nl . $nl;
	}
	return $s;
}
function Table_ComboBox()
{
	global $db,$config,$lang,$nl;
	$tabellen=mysqli_query($config['dbconnection'], 'SHOW TABLES FROM `' . $db . '`');
	$num_tables = 0;
	if (is_resource($tabellen)) {
    	$num_tables=mysqli_num_rows($tabellen);
	}
	$s=$nl . $nl . '' . $nl . ' ---   ' . $nl;
	for ($i=0; $i < $num_tables; $i++)
	{
		$t=mysqli_fetch_row($tabellen);
		$s.='' . $lang['L_TABLE'] . ' `' . $t[0] . '` ' . $nl;
	}
	$s.=' ' . $nl . $nl;
	return $s;
}
function TableComboBox($default='')
{
	global $db,$config,$lang,$nl;
	$sql="SHOW TABLES FROM $db";
	$tabellen=MSD_query($sql);
	$s='                  ' . $nl;
	while ($row = mysqli_fetch_row($tabellen))
	{
		$t= $row[0];
		$s.='`' . $t . '` ' . $nl;
	}
	return $s;
}
function DB_Exists($db)
{
	global $config;
	if (!isset($config['dbconnection'])) MSD_mysql_connect();
	$erg=false;
	$dbs=MSD_query("SHOW DATABASES");
	while ($row=mysqli_fetch_assoc($dbs))
	{
		if (strtolower($row['Database']) == strtolower($db))
		{
			$erg=true;
			break;
		}
	}
	return $erg;
}
function Table_Exists($db, $table)
{
	global $config;
	if (!isset($config['dbconnection'])) MSD_mysql_connect();
	$sqlt="SHOW TABLES FROM `$db`";
	$res=MSD_query($sqlt);
	if ($res)
	{
		$tables=array();
		while ($row=mysqli_fetch_row($res))
		{
			$tables[]=$row[0];
		}
		if (in_array($table,$tables)) return true;
	}
	return false;
}
function DB_Empty($dbn)
{
	$r="DROP DATABASE `$dbn`;\nCREATE DATABASE `$dbn`;";
	return MSD_DoSQL($r);
}
function sqlReturnsRecords($sql)
{
	global $mysql_SQLhasRecords;
	$s=explode(' ',$sql);
	return in_array(strtoupper($s[0]),$mysql_SQLhasRecords) ? 1 : 0;
}
function getCountSQLStatements($sql)
{
	$z=0;
	$l=strlen($sql);
	$inQuotes=false;
	for ($i=0; $i < $l; $i++)
	{
		if ($sql[$i] == "'" || $sql[$i] == '"') $inQuotes=!$inQuotes;
		if (( $sql[$i] == ';' && $inQuotes == false ) || $i == $l - 1) $z++;
	}
	return $z;
}
function splitSQLStatements2Array($sql)
{
	$z=0;
	$sqlArr=array();
	$tmp='';
	$sql=str_replace("\n",'',$sql);
	$l=strlen($sql);
	$inQuotes=false;
	for ($i=0; $i < $l; $i++)
	{
		$tmp.=$sql[$i];
		if ($sql[$i] == "'" || $sql[$i] == '"') $inQuotes=!$inQuotes;
		if ($sql[$i] == ';' && $inQuotes == false)
		{
			$z++;
			$sqlArr[]=$tmp;
			$tmp='';
		}
	}
	if (trim($tmp) != '') $sqlArr[]=$tmp;
	return $sqlArr;
}
function DB_Copy($source, $destination, $drop_source=0, $insert_data=1)
{
	global $config;
	if (!isset($config['dbconnection'])) MSD_mysql_connect();
	$SQL_Array=$t="";
    if (!DB_Exists($destination))
    {
        $res = MSD_DoSQL("CREATE DATABASE `$destination`;");
        if (!$res)
        {
            return false;
        }
    }
	$SQL_Array.="USE `$destination` ;\n";
	$sql="SHOW TABLES FROM $source";
	$tabellen=MSD_query($sql);
	while ($row = mysqli_fetch_row($tabellen))
	{
		$table=strtolower($row[0]);
		$table.='xxxxxxxxxxxxxxxxralf';
		$sqlt="SHOW CREATE TABLE `$source`.`$table`";
		$res=MSD_query($sqlt);
		if ($res)
        {
            $row=mysqli_fetch_row($res);
            $c=$row[1];
            if (substr($c,-1) == ";") $c=substr($c,0,strlen($c) - 1);
            $SQL_Array.=( $insert_data == 1 ) ? "$c SELECT * FROM `$source`.`$table` ;\n" : "$c ;\n";
        }
        else
        {
            return false;
        }
	}
    mysqli_select_db($config['dbconnection'], $destination);
    $res=MSD_DoSQL($SQL_Array);
    if ($drop_source == 1 && $res) MSD_query("DROP DATABASE `$source`;");
    return $res;
}
function Table_Copy($source, $destination, $insert_data, $destinationdb="")
{
	global $config;
	if (!isset($config['dbconnection'])) MSD_mysql_connect();
	$SQL_Array=$t="";
	$sqlc="SHOW CREATE TABLE $source";
	$res=MSD_query($sqlc);
	$row=mysqli_fetch_row($res);
	$c=$row[1];
	$a1=strpos($c,"`");
	$a2=strpos($c,"`",$a1 + 1);
	$c=substr($c,0,$a1 + 1) . $destination . substr($c,$a2);
	if (substr($c,-1) == ";") $c=substr($c,0,strlen($c) - 1);
	$SQL_Array.=( $insert_data == 1 ) ? "$c SELECT * FROM $source ;\n" : "$c ;\n";
	//echo "
$SQL_Array ";
	MSD_DoSQL($SQL_Array);
}
function MSD_DoSQL($sqlcommands, $limit="")
{
	global $config,$out,$numrowsabs,$numrows,$num_befehle,$time_used,$sql;
	if (!isset($sql['parser']['sql_commands'])) $sql['parser']['sql_commands']=0;
	if (!isset($sql['parser']['sql_errors'])) $sql['parser']['sql_errors']=0;
	$sql['parser']['time_used']=getmicrotime();
	if (!isset($config['dbconnection'])) MSD_mysql_connect();
	$out=$sqlcommand='';
	$allSQL=splitSQLStatements2Array($sqlcommands); #explode(';',preg_replace('/\r\n|\n/', '', $sqlcommands));
	$sql_queries=count($allSQL);
	if (!isset($allSQL[$sql_queries - 1])) $sql_queries--;
	if ($sql_queries == 1)
	{
		SQLParser($allSQL[0]);
		$sql['parser']['sql_commands']++;
		$out.=Stringformat(( $sql['parser']['sql_commands'] ),4) . ': ' . $allSQL[0] . "\n";
		$result=MSD_query($allSQL[0]);
	}
	else
	{
	    $result = true;
		for ($i=0; $i < $sql_queries; $i++)
		{
			$allSQL[$i]=trim(rtrim($allSQL[$i]));
			if ($allSQL[$i] != "")
			{
				$sqlcommand.=$allSQL[$i];
				$sqlcommand=SQLParser($sqlcommand);
				if ($sql['parser']['start'] == 0 && $sql['parser']['end'] == 0 && $sqlcommand != '')
				{
					//sql complete
					$sql['parser']['sql_commands']++;
					$out.=Stringformat(( $sql['parser']['sql_commands'] ),4) . ': ' . $sqlcommand . "\n";
					$result=$result && MSD_query($sqlcommand);
					$sqlcommand="";
				}
			}
		}
	}
	$sql['parser']['time_used']=getmicrotime() - $sql['parser']['time_used'];
	return $result;
}
function SQLParser($command, $debug=0)
{
	global $sql;
	$sql['parser']['start']=$sql['parser']['end']=0;
	$sql['parser']['sqlparts']=0;
	if (!isset($sql['parser']['drop'])) $sql['parser']['drop']=0;
	if (!isset($sql['parser']['create'])) $sql['parser']['create']=0;
	if (!isset($sql['parser']['insert'])) $sql['parser']['insert']=0;
	if (!isset($sql['parser']['update'])) $sql['parser']['update']=0;
	if (!isset($sql['parser']['comment'])) $sql['parser']['comment']=0;
	$Backslash=chr(92);
	$s=rtrim(trim(( $command )));
	//Was ist das für eine Anfrage ?
	if (substr($s,0,1) == "#" || substr($s,0,2) == "--")
	{
		$sql['parser']['comment']++;
		$s="";
	}
	elseif (strtoupper(substr($s,0,5)) == "DROP ")
	{
		$sql['parser']['drop']++;
	}
	elseif (strtoupper(substr($s,0,7)) == "CREATE ")
	{
		//Hier nur die Anzahl der Klammern zählen
		$sql['parser']['start']=1;
		$kl1=substr_count($s,"(");
		$kl2=substr_count($s,")");
		if ($kl2 - $kl1 == 0)
		{
			$sql['parser']['start']=0;
			$sql['parser']['create']++;
		}
	}
	elseif (strtoupper(substr($s,0,7)) == "INSERT " || strtoupper(substr($s,0,7)) == "UPDATE ")
	{
		if (strtoupper(substr($s,0,7)) == "INSERT ") $sql['parser']['insert']++;
		else $sql['parser']['update']++;
		$i=strpos(strtoupper($s)," VALUES") + 7;
		$st=substr($s,$i);
		$i=strpos($st,"(") + 1;
		$st=substr($st,$i);
		$st=substr($st,0,strlen($st) - 2);
		$tb=explode(",",$st);
		for ($i=0; $i < count($tb); $i++)
		{
			$first=$B_Esc=$B_Ticks=$B_Dashes=0;
			$v=trim($tb[$i]);
			//Ticks + Dashes zählen
			for ($cpos=2; $cpos <= strlen($v); $cpos++)
			{
				if (substr($v,( -1 * $cpos ),1) == "'")
				{
					$B_Ticks++;
				}
				else
				{
					break;
				}
			}
			for ($cpos=2; $cpos <= strlen($v); $cpos++)
			{
				if (substr($v,( -1 * $cpos ),1) == '"')
				{
					$B_Dashes++;
				}
				else
				{
					break;
				}
			}
			//Backslashes zählen
			for ($cpos=2 + $B_Ticks; $cpos <= strlen($v); $cpos++)
			{
				if (substr($v,( -1 * $cpos ),1) == "\\")
				{
					$B_Esc++;
				}
				else
				{
					break;
				}
			}
			if ($v == "NULL" && $sql['parser']['start'] == 0)
			{
				$sql['parser']['start']=1;
				$sql['parser']['end']=1;
			}
			if ($sql['parser']['start'] == 0 && is_numeric($v))
			{
				$sql['parser']['start']=1;
				$sql['parser']['end']=1;
			}
			if ($sql['parser']['start'] == 0 && substr($v,0,2) == "0X" && strpos($v," ") == false)
			{
				$sql['parser']['start']=1;
				$sql['parser']['end']=1;
			}
			if ($sql['parser']['start'] == 0 && is_object($v))
			{
				$sql['parser']['start']=1;
				$sql['parser']['end']=1;
			}
			if (substr($v,0,1) == "'" && $sql['parser']['start'] == 0)
			{
				$sql['parser']['start']=1;
				if (strlen($v) == 1) $first=1;
				$DELIMITER="'";
			}
			if (substr($v,0,1) == '"' && $sql['parser']['start'] == 0)
			{
				$sql['parser']['start']=1;
				if (strlen($v) == 1) $first=1;
				$DELIMITER='"';
			}
			if ($sql['parser']['start'] == 1 && $sql['parser']['end'] != 1 && $first == 0)
			{
				if (substr($v,-1) == $DELIMITER)
				{
					$B_Delimiter=( $DELIMITER == "'" ) ? $B_Ticks : $B_Dashes;
					//ist Delimiter maskiert?
					if (( $B_Esc % 2 ) == 1 && ( $B_Delimiter % 2 ) == 1 && strlen($v) > 2)
					{
						$sql['parser']['end']=1;
					}
					elseif (( $B_Delimiter % 2 ) == 1 && strlen($v) > 2)
					{
						//ist mit `'` maskiert
						$sql['parser']['end']=0;
					}
					elseif (( $B_Esc % 2 ) == 1)
					{
						//ist mit Backslash maskiert
						$sql['parser']['end']=0;
					}
					else
					{
						$sql['parser']['end']=1;
					}
				}
			}
			if ($debug == 1) echo "" . $sql['parser']['start'] . "/" . $sql['parser']['end'] . "  Feld $i: " . htmlspecialchars($tb[$i]) . "- " . $sql['parser']['sqlparts'] . "  ($B_Ticks / $B_Esc) ' . $lang['L_SQL_OUTPUT'] . ' ';
	if ($meldung != '') $s.=trim($meldung);
	if (isset($sql['parser']['sql_commands']))
	{
		$s.=' ' . $sql['parser']['sql_commands'] . ' ' . $lang['L_SQL_COMMANDS_IN'] . round($sql['parser']['time_used'],4) . $lang['L_SQL_COMMANDS_IN2'] . '
';
		$s.=$lang['L_SQL_OUT1'] . '
' . $sql['parser']['drop'] . '  DROP -, ';
		$s.='
' . $sql['parser']['create'] . '  CREATE -, ';
		$s.='
' . $sql['parser']['insert'] . '  INSERT -, ';
		$s.='
' . $sql['parser']['update'] . '  UPDATE -' . $lang['L_SQL_OUT2'] . '
';
		$s.=$lang['L_SQL_OUT3'] . '
' . $sql['parser']['comment'] . '  ' . $lang['L_SQL_OUT4'] . '
';
		if ($sql['parser']['sql_commands'] < 50) $s.='
' . Highlight_SQL($sqlcommand) . ' ';
		else $s.=$lang['L_SQL_OUT5'];
	}
	elseif ($sqlcommand != '') $s.='
' . $lang['L_SQL_OUTPUT'] . ' ' . Highlight_SQL($sqlcommand) . ' ';
	return $s . '
' . $lang['L_SQL_BEFEHLE'] . ' ';
		if ($when == 0) $r.='';
			$csql=$databases['command_before_dump'][$index];
		}
		else
		{
			$r='';
			$csql=$databases['command_after_dump'][$index];
		}
		$r.='  ' . "\n";
		if (count($SQL_ARRAY) > 0)
		{
			for ($i=0; $i < count($SQL_ARRAY); $i++)
			{
				$s=trim(SQL_String($i));
				$r.='' . SQL_Name($i) . ' ' . "\n";
			}
		}
		$r.=' ';
	}
	return $r;
}
function EngineCombo($default="")
{
	global $config;
	if (!$config['dbconnection']) MSD_mysql_connect();
	$r='BDB ';
		$r.='HEAP ';
		$r.='ISAM ';
		$r.='InnoDB ';
		$r.='MERGE ';
		$r.='MRG_MYISAM ';
		$r.='MyISAM ';
	}
	else
	{
		$res=mysqli_query($config['dbconnection'], "SHOW ENGINES");
		$num=mysqli_num_rows($res);
		for ($i=0; $i < $num; $i++)
		{
			$row=mysqli_fetch_array($res);
			$r.='' . $row['Engine'] . ' ';
		}
	}
	return $r;
}
function CharsetCombo($default="")
{
	global $config;
	if (!MSD_NEW_VERSION)
	{
		return "";
	}
	else
	{
		if (!isset($config['dbconnection'])) MSD_mysql_connect();
		$res=mysqli_query($config['dbconnection'], "SHOW Charset");
		$num=mysqli_num_rows($res);
		$r='' . $row['Charset'] . ' ';
			}
		}
		return $r;
	}
}
function GetCollationArray()
{
	global $config;
	if (!isset($config['dbconnection'])) MSD_mysql_connect();
	$res=mysqli_query($config['dbconnection'], "SHOW Collation");
	$num=@mysqli_num_rows($res);
	$r=Array();
	if (is_array($r))
	{
		for ($i=0; $i < $num; $i++)
		{
			$row=mysqli_fetch_array($res);
			$r[$i]['Collation']=isset($row['Collation']) ? $row['Collation'] : '';
			$r[$i]['Charset']=isset($row['Charset']) ? $row['Charset'] : '';
			$r[$i]['Id']=isset($row['Id']) ? $row['Id'] : '';
			$r[$i]['Default']=isset($row['Default']) ? $row['Default'] : '';
			$r[$i]['Compiled']=isset($row['Compiled']) ? $row['Compiled'] : '';
			$r[$i]['Sortlen']=isset($row['Sortlen']) ? $row['Sortlen'] : '';
		}
	}
	return $r;
}
function CollationCombo($default="", $withcharset=0)
{
	if (!MSD_NEW_VERSION)
	{
		return "";
	}
	else
	{
		$r=GetCollationArray();
		sort($r);
		$s='';
		$s='';
			}
			$s.='' . $r[$i]['Collation'] . ' ';
		}
		return $s . ' ';
	}
}
function AttributeCombo($default='')
{
	$s='unsigned ';
	$s.='unsigned zerofill ';
	return $s;
}
function simple_bbcode_conversion($a)
{
	global $config;
	$tag_start='';
	$tag_end='';
	//replacements
	$a=nl2br($a);
	$a=str_replace('$2 ",$a);
	$a=preg_replace("/\[urltargetself=(.*?)\](.*?)\[\/urltargetself\]/si","$2 ",$a);
	$a=preg_replace("/\[url\](.*?)\[\/url\]/si","$1 ",$a);
	$a=preg_replace("/\[ed2k=\+(.*?)\](.*?)\[\/ed2k\]/si","$2 ",$a);
	$a=preg_replace("/\[ed2k=(.*?)\](.*?)\[\/ed2k\]/si","$2 ",$a);
	$a=preg_replace("/\[center\](.*?)\[\/center\]/si","$1
",$a);
	$a=preg_replace("/\[size=([1-2]?[0-9])\](.*?)\[\/size\]/si","$2 ",$a);
	$a=preg_replace("/\[size=([1-2]?[0-9]):(.*?)\](.*?)\[\/size(.*?)\]/si","$3 ",$a);
	$a=preg_replace("/\[font=(.*?)\](.*?)\[\/font\]/si","$2 ",$a);
	$a=preg_replace("/\[color=(.*?)\](.*?)\[\/color\]/si","$2 ",$a);
	$a=preg_replace("/\[color=(.*?):(.*?)\](.*?)\[\/color(.*?)\]/si","$3 ",$a);
	$a=preg_replace("/\[img\](.*?)\[\/img\]/si","$1 ", $a);
	$a=preg_replace("/\[b(.*?)\](.*?)\[\/b(.*?)\]/si","$2 ",$a);
	//$a=preg_replace("/\[u\](.*?)\[\/u\]/si", "$1 ", $a);
	$a=preg_replace("/\[u(.*?)\](.*?)\[\/u(.*?)\]/si","$2 ",$a);
	//$a=preg_replace("/\[i\](.*?)\[\/i\]/si", "$1 ", $a);
	$a=preg_replace("/\[i(.*?)\](.*?)\[\/i(.*?)\]/si","$2 ",$a);
	//$a=preg_replace("/\[quote\](.*?)\[\/quote\]/si", "$1
", $a);
	$a=preg_replace("/\[quote(.*?)\](.*?)\[\/quote(.*?)\]/si","$2
",$a);
	$a=preg_replace("/\[code(.*?)\](.*?)\[\/code(.*?)\]/si","$2
",$a);
	$a=preg_replace("/\[hide\](.*?)\[\/hide\]/si","$1
",$a);
	$a=preg_replace("/(^|\s)+((http:\/\/)|(www.))(.+)(\s|$)+/Uis"," http://$4$5  ",$a);
	return $tag_start . $a . $tag_end;
}
function ExtractTablenameFromSQL($q)
{
	global $databases,$db,$dbid;
	$tablename='';
	if (strlen($q) > 100) $q=substr($q,0,100);
	$p=trim($q);
	// if we get a list of tables - no current table is selected -> return ''
	if (strtoupper(substr($p,0,17)) == 'SHOW TABLE STATUS') return '';
	// check for SELECT-Statement to extract tablename after FROM
	if (strtoupper(substr($p,0,7)) == 'SELECT ')
	{
		$parts=array();
		$p=substr($p,strpos(strtoupper($p),'FROM') + 5);
		$parts=explode(' ',$p);
		$p=$parts[0];
	}
    // remove keyword DATABASES and the database name after that
    $p = preg_replace('/DATABASE [`]*\w+[`]*/i', '', $p);
    // remove other keywords
	$suchen=array(
               'SHOW DATABASES',
				'SHOW ',
				'SELECT',
				'DROP',
				'INSERT',
				'UPDATE',
				'DELETE',
				'CREATE',
				'TABLE',
				'STATUS',
				'FROM',
				'*'
	);
	$ersetzen=array(
                    '',
					'',
					'',
					'',
					'',
					'',
					'',
					'',
					'',
					'',
					'',
					''
	);
	$cleaned=trim(str_ireplace($suchen,$ersetzen,$p));
	$tablename=$cleaned;
	if (strpos($cleaned,' ')) $tablename=substr($cleaned,0,strpos($cleaned,' '));
	$tablename=str_replace('`','',$tablename); // remove backticks
	// take care of db-name.tablename
	if (strpos($tablename,'.'))
	{
		$p=explode('.',$tablename);
		$databases['db_actual']=$p[0];
		// if database is changed in Query we need to get the index of the actual db
		$db_temp=array_flip($databases['Name']);
		if (isset($db_temp[$databases['db_actual']]))
		{
			$databases['db_selected_index']=$db_temp[$databases['db_actual']];
			$dbid=$databases['db_selected_index'];
		}
		if (isset($_GET['tablename'])) unset($_GET['tablename']);
		//echo "' . $s . ' ' . "\n";
	}
	return $r;
}
function make_options($arr, $selected)
{
	$r='';
	foreach ($arr as $key=>$val)
	{
		$r.='' . $val . ' ' . "\n";
	}
	return $r;
}
/**
 * Reads MySQL field information (depricated: will be substituted by function getExtendedFieldInfos)
 *
 * Reads field information for each field of a MySQL table
 * and fills an array with the keys detected
 *
 * @param $db Database
 * @param $tabelle Table
 * @return array
 */
function getFieldinfos($db, $tabelle)
{
	global $config;
	$fields_infos=Array();
	$t=GetCreateTable($db,$tabelle);
	$sqlf="SHOW FULL FIELDS FROM `$db`.`$tabelle`;";
	$res=MSD_query($sqlf);
	$anz_fields=mysqli_num_rows($res);
	$fields_infos['_primarykeys_']=array();
	$fields_infos['_key_']=array();
	$fields_infos['_uniquekey_']=array();
	$fields_infos['_fulltextkey_']=array();
	$fields_infos['_tableinfo_']=array(
										'ENGINE' => 'MyISAM',
										'AUTO_INCREMENT' => '',
										'DEFAULT CHARSET' => ''
	);
	for ($i=0; $i < $anz_fields; $i++)
	{
		// define defaults
		$fields_infos[$i]['name']='';
		$fields_infos[$i]['size']='';
		$fields_infos[$i]['default']='';
		$fields_infos[$i]['extra']='';
		$fields_infos[$i]['attributes']='';
		$fields_infos[$i]['null']='';
		$fields_infos[$i]['collate']='';
		$fields_infos[$i]['comment']='';
		$fields_infos[$i]['type']='';
		$fields_infos[$i]['privileges']='';
		$row=mysqli_fetch_array($res,MYSQLI_ASSOC);
		//v($row);
		if (isset($row['Collation'])) $fields_infos[$i]['collate']=$row['Collation'];
		if (isset($row['COLLATE'])) $fields_infos[$i]['collate']=$row['COLLATE']; // MySQL <4.1
		if (isset($row['Comment'])) $fields_infos[$i]['comment']=$row['Comment'];
		if (isset($row['Type'])) $fields_infos[$i]['type']=$row['Type'];
		if (isset($row['Field'])) $fields_infos[$i]['name']=$row['Field'];
		$fields_infos[$i]['size']=get_attribut_size_from_type($fields_infos[$i]['type']);
		// remove size from type for readability in output
		$fields_infos[$i]['type']=str_replace('(' . $fields_infos[$i]['size'] . ')','',$fields_infos[$i]['type']);
		// look for attributes, everthing behind the first space is an atribut
		$attributes=explode(' ',$fields_infos[$i]['type'],2);
		if (isset($attributes[1]))
		{
			// we found attributes
			unset($attributes[0]); // delete type
			$fields_infos[$i]['attributes']=trim(implode(' ',$attributes)); //merge all other attributes
			// remove attributes from type
			$fields_infos[$i]['type']=trim(str_replace($fields_infos[$i]['attributes'],'',$fields_infos[$i]['type']));
		}
		if (isset($row['NULL'])) $fields_infos[$i]['null']=$row['NULL'];
		if (isset($row['Null'])) $fields_infos[$i]['null']=$row['Null'];
		if (isset($row['Default'])) $fields_infos[$i]['default']=$row['Default'];
		if (isset($row['Extra'])) $fields_infos[$i]['extra']=$row['Extra'];
		if (isset($row['Privileges'])) $fields_infos[$i]['privileges']=$row['Privileges'];
		if (isset($row['privileges'])) $fields_infos[$i]['privileges']=$row['privileges'];
	}
	// now get key definitions of the table and add info to fields
	$sql='SHOW KEYS FROM `' . $db . '`.`' . $tabelle . '`';
	$res=MSD_query($sql);
	while ($row=mysqli_fetch_array($res,MYSQLI_ASSOC))
	{
		//v($row);
		$key_name=isset($row['Key_name']) ? $row['Key_name'] : '';
		$index_type=isset($row['Index_type']) ? $row['Index_type'] : '';
		$column_name=isset($row['Column_name']) ? $row['Column_name'] : '';
		$non_unique=isset($row['Non_unique']) ? $row['Non_unique'] : '';
		if ($column_name > '')
		{
			// first find indexnr of field
			for ($index=0, $count=sizeof($fields_infos); $index < $count; $index++)
			{
				if ($fields_infos[$index]['name'] == $column_name) break;
			}
			if ($key_name == 'PRIMARY')
				$fields_infos['_primarykeys_'][]=$column_name;
			elseif ($index_type == 'FULLTEXT')
				$fields_infos['_fulltextkey_'][]=$column_name;
			elseif ($non_unique == 0)
				$fields_infos['_uniquekey_'][]=$column_name;
			else
				$fields_infos['_key_'][]=$column_name;
		}
	}
	//v($fields_infos);
	return $fields_infos;
}
/**
 * Reads extened MySQL field information
 *
 * Reads extened field information for each field of a MySQL table
 * and fills an array like
 * array(
 *  [Fieldname][attribut]=value,
 *  ['primary_key']=keys
 * )
 *
 * @param $db Database
 * @param $table Table
 * @return array Field infos
 */
function getExtendedFieldInfo($db, $table)
{
	global $config;
	$fields_infos=Array();
	$t=GetCreateTable($db,$table);
	$sqlf="SHOW FULL FIELDS FROM `$db`.`$table`;";
	$res=MSD_query($sqlf);
	$num_fields=mysqli_num_rows($res);
	$f=array(); //will hold all info
	for ($x=0; $x < $num_fields; $x++)
	{
		$row=mysqli_fetch_array($res,MYSQLI_ASSOC);
		//v($row);
		$i=$row['Field']; // define name of field as index of array
		//define field defaults - this way the index of the array is defined anyway
		$f[$i]['field']='';
		$f[$i]['collation']='';
		$f[$i]['comment']='';
		$f[$i]['type']='';
		$f[$i]['size']='';
		$f[$i]['attributes']='';
		$f[$i]['null']='';
		$f[$i]['default']='';
		$f[$i]['extra']='';
		$f[$i]['privileges']='';
		$f[$i]['primary_keys']=array();
		if (isset($row['Collation'])) $f[$i]['collate']=$row['Collation'];
		if (isset($row['COLLATE'])) $f[$i]['collate']=$row['COLLATE']; // MySQL <4.1
		if (isset($row['Comment'])) $f[$i]['comment']=$row['Comment'];
		if (isset($row['Type'])) $f[$i]['type']=$row['Type'];
		if (isset($row['Field'])) $f[$i]['field']=$row['Field'];
		$f[$i]['size']=get_attribut_size_from_type($f[$i]['type']);
		// remove size from type for readability in output
		$f[$i]['type']=str_replace('(' . $f[$i]['size'] . ')','',$f[$i]['type']);
		// look for attributes, everthing behind the first space is an atribut
		$attributes=explode(' ',$f[$i]['type'],2);
		if (isset($attributes[1]))
		{
			// we found attributes
			unset($attributes[0]); // delete type
			$f[$i]['attributes']=trim(implode(' ',$attributes)); //merge all other attributes
			// remove attributes from type
			$f[$i]['type']=trim(str_replace($f[$i]['attributes'],'',$f[$i]['type']));
		}
		if (isset($row['NULL'])) $f[$i]['null']=$row['NULL'];
		if (isset($row['Null'])) $f[$i]['null']=$row['Null'];
		if (isset($row['Default'])) $f[$i]['default']=$row['Default'];
		if (isset($row['Extra'])) $f[$i]['extra']=$row['Extra'];
		if (isset($row['Privileges'])) $f[$i]['privileges']=$row['Privileges'];
		if (isset($row['privileges'])) $f[$i]['privileges']=$row['privileges'];
	}
	// now get key definitions of the table and add info to field-array
	$sql='SHOW KEYS FROM `' . $db . '`.`' . $table . '`';
	$res=MSD_query($sql);
	while ($row=mysqli_fetch_array($res,MYSQLI_ASSOC))
	{
		//echo "','',$val);
		$val=str_replace(' ','',$val);
		if (!empty($val)){
			$ret.='`' . $key . '`="' . addslashes($val) . '" AND ';
		}
	}
	$ret=substr($ret,0,-5);
	return $ret;
}
/*
 * Array mit Primaerschluesseln aufbauen
 * INPUT: Datenbank.Tabelle (oder nur Tabelle)
 * OUTPUT: Array mit allen Tabellenschluesseln
 * Author: DH
 */
function getPrimaryKeys($db, $table)
{
	$keys=Array();
	$sqlk="SHOW KEYS FROM `" . $db . "`.`" . $table . "`;";
	$res=MSD_query($sqlk);
	while ($row=mysqli_fetch_array($res))
	{
		//wenn Primaerschluessel
		if ($row['Key_name'] == "PRIMARY") $keys['name'][]=$row['Column_name'];
		if ($row['Sub_part'] != null)
		{
			$keys['size'][]=$row['Sub_part'];
		}
		else
		{
			$keys['size'][]='';
		}
	}
	return $keys;
}
/*
 * Array mit allen Feldern aufbauen
 * INPUT: Datenbank.Tabelle
 * OUTPUT: Array mit allen Feldern der Tabelle
 * Author: DH
 */
function getAllFields($db, $table)
{
	$fields=Array();
	$sqlk="DESCRIBE `" . $db . "`.`" . $table . "`;";
	$res=MSD_query($sqlk);
	while ($row=mysqli_fetch_array($res))
	{
		$fields[]=$row['Field'];
	}
	return $fields;
}
/*
 * Alte Primaerschluessel verwerfen, neue Primaerschluessel setzen
 * INPUT: Datenbank.Tabelle, Array mit neuen Primaerschluesseln
 * OUTPUT: true/false
 * Author: DH
 */
function setNewPrimaryKeys($db, $table, $newKeys, $indexSizes)
{
    $sqlSetNewPrimaryKeys="ALTER TABLE `" . $db . "`.`" . $table . "`";
    //wenn es Primaerschluessel gibt, diese loeschen
    $existingKeys = getPrimaryKeys($db, $table);
    if (count($existingKeys) > 0)
    {
        $sqlSetNewPrimaryKeys.=" DROP PRIMARY KEY";
    }
    //wenn min. 1 Schluessel im Array, sonst nur loeschen
	if (count($newKeys) > 0)
	{
        if (count($existingKeys) > 0)
        {
            $sqlSetNewPrimaryKeys.=", ";
        }
        $sqlSetNewPrimaryKeys.=" ADD PRIMARY KEY (";
		foreach ($newKeys as $id => $name)
		{
			if ($id > 0) $sqlSetNewPrimaryKeys.=", ";
			$sqlSetNewPrimaryKeys.="`" . $name . "`";
			if ($indexSizes[$id]) {
				$sqlSetNewPrimaryKeys.=" (" . $indexSizes[$id] . ")";
			}
		}
		$sqlSetNewPrimaryKeys.=")";
	}
	$sqlSetNewPrimaryKeys.=";";
	$res=MSD_query($sqlSetNewPrimaryKeys);
	return $res;
}
function setNewKeys($db, $table, $newKeys, $indexType, $indexName, $indexSizes)
{
    $sqlSetNewKeys="ALTER TABLE `" . $db . "`.`" . $table . "` ";
    $sqlSetNewKeys.="ADD ".$indexType." ";
	if ($indexName)
	{
		 $sqlSetNewKeys.="`" . $indexName ."` ";
	}
	$sqlSetNewKeys.="(";
	foreach ($newKeys as $id => $name)
    {
		if ($id > 0) $sqlSetNewKeys.=", ";
		$sqlSetNewKeys.="`" . $name . "`";
		if ($indexSizes[$id]) {
			$sqlSetNewKeys.=" (" . $indexSizes[$id] . ")";
		}
	}
	$sqlSetNewKeys.=");";
	$res=MSD_query($sqlSetNewKeys);
	return $res;
}
function killKey($db, $table, $indexName)
{
	$sqlKillKey = "ALTER TABLE `".$db."`.`".$table."` DROP INDEX `".$indexName."`";
	$res=MSD_query($sqlKillKey);
	return $res;
}
function get_output_attribut_null($null)
{
	global $lang;
	if ($null == '') return $lang['L_YES'];
	$not_null=array(
					'NO',
					'NOT NULL'
	);
	if (in_array($null,$not_null)) return $lang['L_NO'];
	else return $lang['L_YES'];
}
function get_attribut_size_from_type($type)
{
	$size='';
	$matches=array();
	$pattern='/\((\d.*?)\)/msi';
	preg_match($pattern,$type,$matches);
	if (isset($matches[1])) $size=$matches[1];
	return $size;
}
// Bildet die WHERE-Bedingung zur eindeutigen Identifizierung wenn kein Primaerschluessel vorhanden ist
// erwartet ein Array mit $data[feldname]=wert
function build_recordkey($data)
{
	if (!is_array($data)) return urlencode($data);
	else return urlencode(serialize($data));
}