Description:
When the ngram parser is added to a full-text index without a parser using the inplace DDL algorithm in a separate DDL statement, the full-text index does not change, and data can not be selected by 'MATCH ... AGAINST ...' statement. When the copy DDL algorithm is used or the rebuilt DDL statement is divided into two DDL statement, the problem can be solved.
How to repeat:
step 1: create a table
CREATE TABLE t (name varchar(256)) ENGINE=InnoDB ;
step 2: insert a record
insert into t values('goat勒布朗');
step 3: add a fulltext index without parser
ALTER TABLE t ADD FULLTEXT INDEX ft_index (name);
step 4: use the inplace algorithm to rebuild the index with ngram parser in a DDL statement
ALTER TABLE t
DROP INDEX ft_index ,
ADD FULLTEXT INDEX ft_index (name) WITH PARSER ngram , algorithm = inplace;
The rebuilt fulltext index does not have the ngram parser, and data can not be selected by 'MATCH ... AGAINST ...' statement :
mysql> show create table t;
+-------+-----------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table |
+-------+-----------------------------------------------------------------------------------------------------------------------------------+
| t | CREATE TABLE `t` (
`name` varchar(256) DEFAULT NULL,
FULLTEXT KEY `ft_index` (`name`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 |
+-------+-----------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)
mysql> SELECT * FROM t WHERE MATCH(name) AGAINST ('goat');
Empty set (0.00 sec)
step 5: When the copy algorithm is used or rebuild the index by two DDL statement, the index will be successfully rebuilt, and data can be selected by 'MATCH ... AGAINST ...' statement:
ALTER TABLE t
DROP INDEX ft_index ,
ADD FULLTEXT INDEX ft_index (name) WITH PARSER ngram , algorithm = copy;
or
ALTER TABLE t DROP INDEX ft_index;
ALTER TABLE t ADD FULLTEXT INDEX ft_index (name) WITH PARSER ngram , algorithm = inplace;
the full-text index is changed with PARSER `ngram`:
mysql> show create table t;
+-------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table |
+-------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| t | CREATE TABLE `t` (
`name` varchar(256) DEFAULT NULL,
FULLTEXT KEY `ft_index` (`name`) /*!50100 WITH PARSER `ngram` */
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 |
+-------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.01 sec)
and data can be selected by 'MATCH ... AGAINST ...' statement:
mysql> SELECT * FROM t WHERE MATCH(name) AGAINST ('goat');
+--------------+
| name |
+--------------+
| goat勒布朗 |
+--------------+
1 row in set (0.00 sec)
Suggested fix:
Suggested fix:
When the full-text index's parser is changed, the ful-text index should be to be rebuilt.
I will give fixed code and some test case later.