mysql 如何进行快速的昵称搜索模糊查询

WBOY
Lepaskan: 2016-09-21 14:13:05
asal
1134 orang telah melayarinya

mysql 进行昵称搜索模糊查询,如果用户多了 like 查询会很慢,请问如何解决?

回复内容:

mysql 进行昵称搜索模糊查询,如果用户多了 like 查询会很慢,请问如何解决?

  1. 在数据库的此表中的昵称这个字段建立索引

    key `nikename`(`nikename`)

  2. 全文索引配合sql语句

    ALTER TABLE `user` ADD FULLTEXT `fidx_user_nikename` (`nickname`)

然后用以下方式查询

<code>SELECT * FROM \`user\` WHERE MATCH (nickname)AGAINST ('xxx')</code>
Salin selepas log masuk

如果是like %name%,那在我的认知范围内是没辙了,如果前边没有%可以建索引,或者试试LOCATE函数,不过估计没啥效果。

instr呢?

模糊搜索的话,上分词吧。sphinx coreseek 或者xunsearch(迅搜)

如果你的mysql版本大于5.7, 自带ngram全文索引支持中文分词,我在项目中已用,用法网上已经有教程了

使用搜索引擎,把常用搜索的字段索引起来,然后在结合缓存一起使用

Label berkaitan:
php
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!