summaryrefslogtreecommitdiff
path: root/sql/sql_table.cc
diff options
context:
space:
mode:
authorunknown <serg@serg.mysql.com>2001-10-23 10:52:51 +0200
committerunknown <serg@serg.mysql.com>2001-10-23 10:52:51 +0200
commit11572916ffb543e5b89db156a46a265d251bf768 (patch)
tree6f045be38734a0b7be25eee3c7755b68e6152904 /sql/sql_table.cc
parent151ffe886b4b21499471658fdf01ea8347287092 (diff)
downloadmariadb-git-11572916ffb543e5b89db156a46a265d251bf768.tar.gz
HA_NO_FULLTEXT_KEY and an appropriate error message
include/mysqld_error.h: New error message added libmysql/violite.c: FreeBSD fix sql/ha_berkeley.h: HA_NO_FULLTEXT_KEY sql/ha_heap.h: HA_NO_FULLTEXT_KEY sql/ha_innobase.h: HA_NO_FULLTEXT_KEY sql/ha_isam.h: HA_NO_FULLTEXT_KEY sql/ha_isammrg.h: HA_NO_FULLTEXT_KEY sql/ha_myisammrg.h: HA_NO_FULLTEXT_KEY sql/share/czech/errmsg.txt: New error message added sql/share/danish/errmsg.txt: New error message added sql/share/dutch/errmsg.txt: New error message added sql/share/english/errmsg.txt: New error message added sql/share/estonian/errmsg.txt: New error message added sql/share/french/errmsg.txt: New error message added sql/share/german/errmsg.txt: New error message added sql/share/greek/errmsg.txt: New error message added sql/share/hungarian/errmsg.txt: New error message added sql/share/italian/errmsg.txt: New error message added sql/share/japanese/errmsg.txt: New error message added sql/share/korean/errmsg.txt: New error message added sql/share/norwegian-ny/errmsg.txt: New error message added sql/share/norwegian/errmsg.txt: New error message added sql/share/polish/errmsg.txt: New error message added sql/share/portuguese/errmsg.txt: New error message added sql/share/romanian/errmsg.txt: New error message added sql/share/russian/errmsg.txt: New error message added sql/share/slovak/errmsg.txt: New error message added sql/share/spanish/errmsg.txt: New error message added sql/share/swedish/errmsg.txt: New error message added sql/share/ukrainian/errmsg.txt: New error message added sql/sql_table.cc: FULLTEXT checks fixed sql/violite.c: FreeBSD fix
Diffstat (limited to 'sql/sql_table.cc')
-rw-r--r--sql/sql_table.cc31
1 files changed, 15 insertions, 16 deletions
diff --git a/sql/sql_table.cc b/sql/sql_table.cc
index 4735e8a08ec..237a1f63e44 100644
--- a/sql/sql_table.cc
+++ b/sql/sql_table.cc
@@ -413,6 +413,15 @@ int mysql_create_table(THD *thd,const char *db, const char *table_name,
key_info->key_parts=(uint8) key->columns.elements;
key_info->key_part=key_part_info;
+ if (key->type == Key::FULLTEXT)
+ {
+ if (file->option_flag() & HA_NO_FULLTEXT_KEY)
+ {
+ my_error(ER_TABLE_CANT_HANDLE_FULLTEXT, MYF(0));
+ DBUG_RETURN(-1);
+ }
+ }
+
List_iterator<key_part_spec> cols(key->columns);
for (uint column_nr=0 ; (column=cols++) ; column_nr++)
{
@@ -428,13 +437,8 @@ int mysql_create_table(THD *thd,const char *db, const char *table_name,
column->field_name);
DBUG_RETURN(-1);
}
- if (key->type == Key::FULLTEXT &&
- (file->option_flag() & HA_NO_FULLTEXT_KEY))
- {
- my_printf_error(ER_WRONG_KEY_COLUMN, ER(ER_WRONG_KEY_COLUMN), MYF(0),
- column->field_name);
- DBUG_RETURN(-1);
- }
+ if (key->type == Key::FULLTEXT)
+ column->length=1; /* ft-code ignores it anyway :-) */
if (f_is_blob(sql_field->pack_flag))
{
if (!(file->option_flag() & HA_BLOB_KEY))
@@ -445,15 +449,10 @@ int mysql_create_table(THD *thd,const char *db, const char *table_name,
}
if (!column->length)
{
- if (key->type == Key::FULLTEXT)
- column->length=1; /* ft-code ignores it anyway :-) */
- else
- {
- my_printf_error(ER_BLOB_KEY_WITHOUT_LENGTH,
- ER(ER_BLOB_KEY_WITHOUT_LENGTH),MYF(0),
- column->field_name);
- DBUG_RETURN(-1);
- }
+ my_printf_error(ER_BLOB_KEY_WITHOUT_LENGTH,
+ ER(ER_BLOB_KEY_WITHOUT_LENGTH),MYF(0),
+ column->field_name);
+ DBUG_RETURN(-1);
}
}
if (!(sql_field->flags & NOT_NULL_FLAG))