table_options:
TYPE = {BDB | HEAP | ISAM | InnoDB | MERGE | MRG_MYISAM | MYISAM }
+ or ENGINE = {BDB | HEAP | ISAM | InnoDB | MERGE | MRG_MYISAM | MYISAM }
or AUTO_INCREMENT = #
or AVG_ROW_LENGTH = #
+ or [ DEFAULT ] CHARACTER SET charset_name
or CHECKSUM = {0 | 1}
+ or COLLATE collation_name
or COMMENT = "string"
or MAX_ROWS = #
or MIN_ROWS = #
or DATA DIRECTORY="absolute path to directory"
or INDEX DIRECTORY="absolute path to directory"
+
A subset of the ALTER TABLE syntax that allows addition of foreign keys:
ALTER [IGNORE] TABLE tbl_name alter_specification [, alter_specification] ...
push @{ $tables{ $item{'table_name'} }{'indices'} },
{
name => $item[4],
- type => $item[2] ? 'unique' : 'normal',
+ type => $item[2][0] ? 'unique' : 'normal',
fields => $item[8],
}
;
name_with_opt_paren : NAME parens_value_list(s?)
{ $item[2][0] ? "$item[1]($item[2][0][0])" : $item[1] }
-UNIQUE : /unique/i { 1 }
+UNIQUE : /unique/i
KEY : /key/i | /index/i
$comment =~ s/'$//;
$return = { comment => $comment };
}
- | /(default )?(charset|character set)/i /\s*=\s*/ WORD
+ | /(default )?(charset|character set)/i /\s*=?\s*/ WORD
{
$return = { 'CHARACTER SET' => $item[3] };
}
+ | /collate/i WORD
+ {
+ $return = { 'COLLATE' => $item[2] }
+ }
| WORD /\s*=\s*/ WORD
{
$return = { $item[1] => $item[3] };
COMMA : ','
-NAME : "`" /\w+/ "`"
+BACKTICK : '`'
+
+NAME : BACKTICK /\w+/ BACKTICK
{ $item[2] }
| /\w+/
{ $item[1] }
}
elsif ( lc $type =~ /(float|double|decimal|numeric|real|fixed|dec)/ ) {
my $old_size = (ref $size || '') eq 'ARRAY' ? $size : [];
- $changed = @$old_size != 2 && $old_size->[0] != 8 && $old_size->[1] != 2;
+ $changed = @$old_size != 2 || $old_size->[0] != 8 || $old_size->[1] != 2;
$size = [8,2];
}
}