SELECT * FROM data_1 WHERE MATCH (毕业学校,家庭住址) AGAINST ('+"西安・交通大学" +"(北京、工业大学)" +"西安(高新区)"' IN BOOLEAN MODE)
SELECT * FROM data_1 WHERE MATCH (毕业学校,家庭住址) AGAINST ('+"西安・" +"北京、工业大学)" +"西安("' IN BOOLEAN MODE)
SELECT * FROM data_1 WHERE MATCH (毕业学校,家庭住址) AGAINST ('+"西安・" +"北京、工业大学" +"西安("' IN BOOLEAN MODE)
SELECT * FROM data_1 WHERE MATCH (毕业学校,家庭住址) AGAINST ('+"西安・" +"北京、工业大学" +"西安"' IN BOOLEAN MODE)
以上sql语句都找不到
SELECT * FROM data_1 WHERE MATCH (毕业学校,家庭住址) AGAINST ('+"西安" +"北京" +"高新区"' IN BOOLEAN MODE)
SELECT * FROM data_1 WHERE MATCH (毕业学校,家庭住址) AGAINST ('+"西安・" +"北京、" +"西安("' IN BOOLEAN MODE)
以上这两条sql语句则可以找到
全文索引已经重新做过 create fulltext index search_index_fulltext1 on data_1(毕业学校,家庭住址) with parser ngram;
之所以使用ngram分词是因为我的字段内容既有中午也有日文。
在my.ini里面也已添加这一句 ft_stopword_file=E:\phpstudy_pro\Extensions\MySQL8.0.12\share\stopwords.txt
环境是php7.4.3 + mysql8.0.12
通过最后一条成功的sql看,似乎不能说是由于"・ 、( )" 等特殊符号引起的查询错误,但好像又有影响,怎么消除这种影响呢?
因为我最希望用的语句是第一条【 SELECT * FROM data_1 WHERE MATCH (毕业学校,家庭住址) AGAINST ('+"西安・交通大学" +"(北京、工业大学)" +"西安(高新区)"' IN BOOLEAN MODE)】,原因是我的数据结构大多数是这样的,我的搜索条件输入界面的自动完成提示给出的数据也是这样的带括号或带点的。
之所以要用MATCH ...AGAINST的方式查询,是因为毕业学校和家庭住址内的数据有很多空格,不用全文搜索不行,但要用全文搜索又想走索引就只能用这种方式。
也肯定不是字符编码的问题,因为我都确认和确保了数据库和前端查询时都统一使用的是UTF-8编码。