diff options
author | Brion Vibber <brion@pobox.com> | 2010-11-01 13:27:44 -0700 |
---|---|---|
committer | Brion Vibber <brion@pobox.com> | 2010-11-01 13:27:44 -0700 |
commit | 692ef9c3309bde60346beb32386ff17157e0a5e2 (patch) | |
tree | d07defd6b9e6e95e5c30eb5c2234dce7f5ed8fb2 | |
parent | 96521f38d2f6db7a85e17f2f7f6e4eabeaa06cf8 (diff) |
Include fulltext indexes in MySQL table create
-rw-r--r-- | lib/mysqlschema.php | 14 | ||||
-rw-r--r-- | lib/schema.php | 25 |
2 files changed, 37 insertions, 2 deletions
diff --git a/lib/mysqlschema.php b/lib/mysqlschema.php index a2581e6d8..c3d3501c7 100644 --- a/lib/mysqlschema.php +++ b/lib/mysqlschema.php @@ -245,6 +245,20 @@ class MysqlSchema extends Schema } /** + * Append an SQL statement with an index definition for a full-text search + * index over one or more columns on a table. + * + * @param array $statements + * @param string $table + * @param string $name + * @param array $def + */ + function appendCreateFulltextIndex(array &$statements, $table, $name, array $def) + { + $statements[] = "CREATE FULLTEXT INDEX $name ON $table " . $this->buildIndexList($def); + } + + /** * Close out a 'create table' SQL statement. * * @param string $name diff --git a/lib/schema.php b/lib/schema.php index 671af8a21..2e2795588 100644 --- a/lib/schema.php +++ b/lib/schema.php @@ -168,17 +168,24 @@ class Schema } } - // Multi-value indexes are advisory and for best portability - // should be created as separate statements. + // Wrap the CREATE TABLE around the main body chunks... $statements = array(); $statements[] = $this->startCreateTable($name, $def) . "\n" . implode($sql, ",\n") . "\n" . $this->endCreateTable($name, $def); + + // Multi-value indexes are advisory and for best portability + // should be created as separate statements. if (!empty($def['indexes'])) { foreach ($def['indexes'] as $col => $colDef) { $this->appendCreateIndex($statements, $name, $col, $colDef); } } + if (!empty($def['fulltext indexes'])) { + foreach ($def['fulltext indexes'] as $col => $colDef) { + $this->appendCreateFulltextIndex($statements, $name, $col, $colDef); + } + } return $statements; } @@ -283,6 +290,20 @@ class Schema } /** + * Append an SQL statement with an index definition for a full-text search + * index over one or more columns on a table. + * + * @param array $statements + * @param string $table + * @param string $name + * @param array $def + */ + function appendCreateFulltextIndex(array &$statements, $table, $name, array $def) + { + throw new Exception("Fulltext index not supported in this database"); + } + + /** * Append an SQL statement to drop an index from a table. * * @param array $statements |