php - mysql 如何进行快速的昵称搜索模糊查询
天蓬老师
天蓬老师 2017-04-11 10:27:16
[PHP讨论组]

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

天蓬老师
天蓬老师

欢迎选择我的课程,让我们一起见证您的进步~~

全部回复(6)
伊谢尔伦
  1. 在数据库的此表中的昵称这个字段建立索引

    key `nikename`(`nikename`)

  2. 全文索引配合sql语句

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

然后用以下方式查询

SELECT * FROM \`user\` WHERE MATCH (nickname)AGAINST ('xxx')
高洛峰

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

PHP中文网

instr呢?

阿神

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

ringa_lee

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

巴扎黑

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

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号