fulltext

MySQL中文索引插件mysqlcft安装及使用

那年仲夏 提交于 2020-03-02 05:47:43
MySQL中文索引插件mysqlcft安装及使用 1. MySQL 必须是动态编译安装的,以便加载动态链接库。 2. 编辑 MySQL 配置文件 my.cnf ,在 [mysqld] 段中加入 ft_min_word_len=1 (意为最小词所占字节数) 3. 安装 mysqlcft 中文全文索引插件 从命令行登入 MySQL 服务器 查看 MySQL 插件目录 Show variables like ‘plugin_dir’; 下载 mysqlcft 中文索引插件,解压后复制 mysqlcft.so 文件到 MySQL 的插件目录下 https://code.google.com/p/mysqlcft 有 32 位与 64 位可选 开始安装 mysqlcft.so 插件 Install plugin mysqlcft soname ‘mysqlcft.so’; 查看 mysqlcft.so 插件是否安装成功 show plugins; 4. 卸载 mysqlcft.so 插件,卸载前请先删除使用 mysqlcft 建立的全文索引。 uninstall plugin mysqlcft; 5. 为已经存在的表添加 mysqlcft 中文全文索引 创建单列全文索引 alter ignore table 数据库名 . 表名 add fulltext index 全文索引名 ( 字段名 )

zg手册 之 Mysql 开发(1)-- 中文全文检索插件开发

这一生的挚爱 提交于 2019-11-29 14:02:55
目前的中文检索查询方案 基于数据库的模糊匹配(运行时字符串查找,查询速度比较慢) 专有的全文检索引擎(sphinx, lucene等) 我曾经遇到一个项目,数据量在百万级别,不需要高级的全文检索方式(没有复杂的匹配需求,没有复杂的过滤条件),只是需要根据关键词检索数据,当时采用的 mysql 全文检索插件的方式来满足的项目需求。 Mysql 的中文全文检索插件开发 Mysql 的 MyISAM 引擎支持第三方的全文检索插件,可以用第三方插件替换默认的全文检索插件。 在全文检索插件中提供中文分词算法,告诉MyISAM如何分词,并创建索引。 查询的时候通过插件分词,查询索引快速定位数据记录。 插件开发的具体方法 主要通过代码注释描述插件的开发方法,创建文件 tft.c,代码如下 #include <stdlib.h> #include <ctype.h> // mysql 插件必须包含的头文件 #include <mysql/plugin.h> // 这是我自己写的一个分词库,没有什么优化,可以替换为其他开源的实现。 #include <st_darts.h> #include <st_utils.h> #if !defined(__attribute__) && (defined(__cplusplus) \ || !defined(__GNUC__) || __GNUC__ ==