mysql匹配_MySQL匹配全文

我试图用mysql进行全文搜索,以匹配字符串.问题在于它首先返回了奇怪的结果.

例如,字符串’passat 2.0 tdi’:

AND MATCH (

records_veiculos.titulo,records_veiculos.descricao

)

AGAINST (

'passat 2.0 tdi' WITH QUERY EXPANSION

)

作为第一个结果返回这个(其他人都很好):

Volkswagen Passat Variant 1.9 TDI- ANO 2003

这是不正确的,因为在这个例子中没有“2.0”.

会是什么呢?

编辑:此外,由于这可能是一个大型数据库(期望高达500.000条记录),这种搜索方法是否最适合自己,或者安装任何其他搜索引擎如Sphinx会更好吗?或者如果没有,如何显示相关结果?

edit2:对于记录,尽管问题被标记为已回答,但MySQL分隔符的问题仍然存在,因此如果有人对如何逃避分隔符有任何建议,那么将会受到赞赏并且值得获得500分.我发现增加结果集的sollution是用IN BOOLEAN MODE替换WITH QUERY EXPANSION,使用运算符强制引擎得到我需要的单词,如:

AND MATCH (

records_veiculos.titulo,records_veiculos.descricao

)

AGAINST (

'+passat +2.0 +tdi' IN BOOLEAN MODE

)

它根本没有解决,但至少结果的相关性发生了显着变化.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值