// Get the definition
if (is_null($definition))
$definition = db_definition();
-
+
// Compare it
foreach ($definition AS $name => $structure) {
$sql3="";
if (!isset($database[$name])) {
$r = db_create_table($name, $structure["fields"], $verbose, $action);
- if(false === $r)
+ if(false === $r) {
$errors .= t('Errors encountered creating database tables.').$name.EOL;
+ }
} else {
// Drop the index if it isn't present in the definition and index name doesn't start with "local_"
foreach ($database[$name]["indexes"] AS $indexname => $fieldnames)
if ($parameters["extra"] != "")
$fieldstruct .= " ".$parameters["extra"];
- if (($parameters["primary"] != "") AND $create)
- $fieldstruct .= " PRIMARY KEY";
+ /*if (($parameters["primary"] != "") AND $create)
+ $fieldstruct .= " PRIMARY KEY";*/
return($fieldstruct);
}
$r = true;
$sql = "";
+
$sql_rows = array();
+ $primary_keys = array();
foreach($fields AS $fieldname => $field) {
$sql_rows[] = "`".dbesc($fieldname)."` ".db_field_command($field);
+ if (x($field,'primary') and $field['primary']!=''){
+ $primary_keys[] = $fieldname;
+ }
}
if (!is_null($indexes)) {
}
}
+ if (count($primary_keys)>0) {
+ $sql_rows[] = sprintf("PRIMARY KEY(`%s`)", implode("`,`", $primary_keys));
+ }
+
$sql = implode(",\n\t", $sql_rows);
$sql = sprintf("CREATE TABLE IF NOT EXISTS `%s` (\n\t", dbesc($name)).$sql."\n) DEFAULT CHARSET=utf8";
-
if ($verbose)
echo $sql.";\n";