MYSQL match against 疑义
程序员文章站
2022-05-24 15:09:37
...
MYSQL match against 疑问
-- phpMyAdmin SQL Dump
-- version 2.10.2
-- http://www.phpmyadmin.net
--
-- 主机: localhost
-- 生成日期: 2013 年 01 月 21 日 03:14
-- 服务器版本: 5.0.45
-- PHP 版本: 5.2.3
SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";
--
-- 数据库: `test`
--
-- --------------------
--
-- 表的结构 `city`
--
CREATE TABLE `city` (
`city_id` int(11) NOT NULL auto_increment,
`city` varchar(50) NOT NULL,
`pos` varchar(50) NOT NULL,
`level` tinyint(4) NOT NULL,
PRIMARY KEY (`city_id`),
FULLTEXT KEY `city` (`city`)
) ENGINE=MyISAM DEFAULT CHARSET=gbk AUTO_INCREMENT=11 ;
--
-- 导出表中的数据 `city`
--
INSERT INTO `city` VALUES (1, '中国', '1', 1);
INSERT INTO `city` VALUES (2, '广州天河区', '1,2', 2);
INSERT INTO `city` VALUES (3, '深圳', '1,3', 2);
INSERT INTO `city` VALUES (4, '宝安', '1,3,4', 3);
INSERT INTO `city` VALUES (5, '南头', '1,3,5', 3);
INSERT INTO `city` VALUES (6, '福田', '1,3,6', 3);
INSERT INTO `city` VALUES (7, '天河', '1,2,7', 3);
INSERT INTO `city` VALUES (8, '沙河', '1,2,7,8', 4);
INSERT INTO `city` VALUES (9, '沙河', '1,2,7,9', 4);
INSERT INTO `city` VALUES (10, 'hello world my friend', '', 0);
SELECT *
FROM `city`
WHERE MATCH (
`city`
)
AGAINST (
'hello'
)
上述sql 匹配不了city_id为10的记录 为什么呢? 匹配 AGAINST ('world') 就可以,应该不是长度问题。 求助大神,先谢谢啦!!!
-- phpMyAdmin SQL Dump
-- version 2.10.2
-- http://www.phpmyadmin.net
--
-- 主机: localhost
-- 生成日期: 2013 年 01 月 21 日 03:14
-- 服务器版本: 5.0.45
-- PHP 版本: 5.2.3
SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";
--
-- 数据库: `test`
--
-- --------------------
--
-- 表的结构 `city`
--
CREATE TABLE `city` (
`city_id` int(11) NOT NULL auto_increment,
`city` varchar(50) NOT NULL,
`pos` varchar(50) NOT NULL,
`level` tinyint(4) NOT NULL,
PRIMARY KEY (`city_id`),
FULLTEXT KEY `city` (`city`)
) ENGINE=MyISAM DEFAULT CHARSET=gbk AUTO_INCREMENT=11 ;
--
-- 导出表中的数据 `city`
--
INSERT INTO `city` VALUES (1, '中国', '1', 1);
INSERT INTO `city` VALUES (2, '广州天河区', '1,2', 2);
INSERT INTO `city` VALUES (3, '深圳', '1,3', 2);
INSERT INTO `city` VALUES (4, '宝安', '1,3,4', 3);
INSERT INTO `city` VALUES (5, '南头', '1,3,5', 3);
INSERT INTO `city` VALUES (6, '福田', '1,3,6', 3);
INSERT INTO `city` VALUES (7, '天河', '1,2,7', 3);
INSERT INTO `city` VALUES (8, '沙河', '1,2,7,8', 4);
INSERT INTO `city` VALUES (9, '沙河', '1,2,7,9', 4);
INSERT INTO `city` VALUES (10, 'hello world my friend', '', 0);
SELECT *
FROM `city`
WHERE MATCH (
`city`
)
AGAINST (
'hello'
)
上述sql 匹配不了city_id为10的记录 为什么呢? 匹配 AGAINST ('world') 就可以,应该不是长度问题。 求助大神,先谢谢啦!!!
against match
------解决方案--------------------
1、全文检索会忽略掉一些语气词、问候词。因为他们出现的太频繁,却又无法缩小搜索的范围
2、mysql 的全文检索不支持宽字符集,因此你的测试并无实际意义
------解决方案--------------------
hello是stop word所以搜不到
http://dev.mysql.com/doc/refman/5.5/en/fulltext-stopwords.html
------解决方案--------------------
1、全文检索会忽略掉一些语气词、问候词。因为他们出现的太频繁,却又无法缩小搜索的范围
2、mysql 的全文检索不支持宽字符集,因此你的测试并无实际意义
------解决方案--------------------
hello是stop word所以搜不到
http://dev.mysql.com/doc/refman/5.5/en/fulltext-stopwords.html
相关文章
相关视频
专题推荐
-
独孤九贱-php全栈开发教程
全栈 170W+
主讲:Peter-Zhu 轻松幽默、简短易学,非常适合PHP学习入门
-
玉女心经-web前端开发教程
入门 80W+
主讲:灭绝师太 由浅入深、明快简洁,非常适合前端学习入门
-
天龙八部-实战开发教程
实战 120W+
主讲:西门大官人 思路清晰、严谨规范,适合有一定web编程基础学习
上一篇: Python- yield 用法详解
下一篇: 为什么这段代码没效果
推荐阅读
-
Mysql全文搜索match against的用法
-
Mysql全文搜索match against的用法
-
mysql百万级全文索引及match快速查找
-
mysql全文模糊搜索MATCH AGAINST方法示例
-
Column count doesn't match value count at row 1_MySQL
-
mysql_insert_id的疑义
-
使用Mysql全文搜索Full-Text (fulltext和 match...against)_MySQL
-
Mysql全文搜索match against的用法_MySQL
-
Column count doesn't match value count at row 1_MySQL
-
mysql百万级全文索引及match快速查找
网友评论
文明上网理性发言,请遵守 新闻评论服务协议
我要评论