亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > MySQL 全文檢索的使用示例

MySQL 全文檢索的使用示例

熱門標簽:400電話辦理服務價格最實惠 呂梁外呼系統 催天下外呼系統 html地圖標注并導航 大豐地圖標注app 南太平洋地圖標注 武漢電銷機器人電話 北京金倫外呼系統 400電話變更申請

1. 環境準備

MySQL 5.7.6之前,全文索引只支持英文全文索引,不支持中文全文索引,需要利用分詞器把中文段落預處理拆分成單詞,然后存入數據庫。 MySQL 5.7.6開始,MySQL內置了ngram全文解析器,用來支持中文、日文、韓文分詞。 本文使用的MySQL 版本是5.7.22,InnoDB數據庫引擎。

所以這里需要MySQL的版本大于5.7.6

-- 查看mysql的版本
mysql> select version();
+-----------+
| version() |
+-----------+
| 5.7.33    |
+-----------+
1 row in set (0.02 sec)

在 mysql 配置文件中添加分詞以及最小詞語長度 (如果已經配置可以忽略)

ft_min_word_len 最小字符長度默認為 4,在英文條件下確實比較合理中文情況下需要修改;

ngram_token_size 分詞的最小長度 舉個例子 不同長度對 你好世界 的分詞

n=1: '你', '好', '世', '界' 
n=2: '你好', '好世', '世界' 
n=3: '你好世', '好世界' 
n=4: '你好世界'
# /etc/mysql/mysql.conf.d/mysqld.cnf

ft_min_word_len = 2
ngram_token_size = 2


# 如果沒有則新增配置
echo 'ft_min_word_len = 2
ngram_token_size = 2' >> mysqld.cnf

# 重啟服務
/etc/init.d/mysql restart

-- 查看配置
mysql> 
SHOW VARIABLES LIKE 'ft_min_word_len';
SHOW VARIABLES LIKE 'ngram_token_size';
+-----------------+-------+
| Variable_name   | Value |
+-----------------+-------+
| ft_min_word_len | 2     |
+-----------------+-------+
1 row in set (0.02 sec)
 
+------------------+-------+
| Variable_name    | Value |
+------------------+-------+
| ngram_token_size | 2     |
+------------------+-------+
1 row in set (0.03 sec)


2. 數據準備

-- mysql 于全文檢索的demo

mysql> CREATE TABLE `articles` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `title` varchar(50) DEFAULT NULL COMMENT '主題',
  `content` longtext NOT NULL COMMENT '內容',
  PRIMARY KEY (`id`),
  FULLTEXT KEY `title_content_index` (`content`,`title`) /*!50100 WITH PARSER `ngram` */ 
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;
Query OK, 0 rows affected (0.20 sec)
 

mysql> INSERT INTO articles (`title`, `content`) VALUES
        ('如果','今生今世 永不再將你想起 
除了
除了在有些個
因落淚而濕潤的夜里 如果
如果你愿意'),
        ('愛情','有一天路標遷了希望你能從容
有一天橋墩斷了希望你能渡越
有一天棟梁倒了希望你能堅強
有一天期待蔫了希望你能理解'),
        ('遠和近','你 一會看我
一會看云
我覺得
你看我時很遠
你看云時很近'),
        ('斷章','你站在橋上看風景,
看風景人在樓上看你。
明月裝飾了你的窗子,
你裝飾了別人的夢。'),
        ('獨語','我向你傾吐思念
你如石像
沉默不應
如果沉默是你的悲抑
你知道這悲抑
最傷我心');

Query OK, 5 rows affected (0.08 sec)
Records: 5  Duplicates: 0  Warnings: 0
 
mysql> SELECT * from articles where match(content, title) against('風景' in  NATURAL LANGUAGE MODE) LIMIT 10;
+----+--------+--------------------------------------------------------------------------------------------------------------------------+
| id | title  | content                                                                                                                  |
+----+--------+--------------------------------------------------------------------------------------------------------------------------+
| 10 | 斷章 |  你站在橋上看風景,
看風景人在樓上看你。
明月裝飾了你的窗子,
你裝飾了別人的夢。 |
+----+--------+--------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.02 sec)

3. 開始表演

  • 自然語言模式(NATURAL LANGUAGE MODE)

自然語言模式是MySQL 默認的全文檢索模式。自然語言模式不能使用操作符,不能指定關鍵詞必須出現或者必須不能出現等復雜查詢。

  • 布隆模式(BOOLEAN MODE)

BOOLEAN模式可以使用操作符,可以支持指定關鍵詞必須出現或者必須不能出現或者關鍵詞的權重高還是低等復雜查詢。

  • 查詢擴展(QUERY EXPANSION)

查詢的結果不僅匹配出結果同時可以聯想出其他你需要的結果。(類似關聯查詢,但是官網推薦僅支持短語查詢 否則會出現很多臟數據)

-- 自然語言模式(NATURAL LANGUAGE MODE)查詢并得到評分

mysql> SELECT id, title, MATCH ( content, title ) against ( '風景' IN NATURAL LANGUAGE MODE ) AS score  FROM articles;
+----+-----------+--------------------+
| id | title     | score              |
+----+-----------+--------------------+
|  7 | 如果    |                  0 |
|  8 | 愛情    |                  0 |
|  9 | 遠和近 |                  0 |
| 10 | 斷章    | 0.9771181344985962 |
| 11 | 獨語    |                  0 |
+----+-----------+--------------------+
5 rows in set (0.02 sec)

-- 布隆模式(BOOLEAN MODE) 可以組合查詢

mysql> SELECT id, title  FROM articles where MATCH ( content, title ) against ( '+風景 -愛情' IN BOOLEAN MODE );
+----+--------+
| id | title  |
+----+--------+
| 10 | 斷章 |
+----+--------+
1 row in set (0.01 sec)

-- 查詢擴展(QUERY EXPANSION) 可以聯想出其他結果 
mysql> SELECT id, title  FROM articles where MATCH ( content, title ) against ( '風景' WITH QUERY EXPANSION );
+----+--------+
| id | title  |
+----+--------+
| 10 | 斷章 |
| 11 | 獨語 |
+----+--------+
2 rows in set (0.02 sec)
 

4. 分詞引擎

目前官網 MeCab Full-Text Parser 有支持日語的分詞插件(可以更好的理解語義)

內置的 full-text parser 因為英文中單詞的邊界默認是空格,所以在處理英文文本時可以簡單的使用空格作為分隔符。但是在處理中文時需要理解語義的基礎上進行有效的分詞,所以在處理中文、日文、韓文MySQL 提供了 ngram full-text (本文的配置就是 基于ngram的中文分詞)

總結

優點

  • 對比 like 查詢效率有提升(具體提升的測試沒有做)
  • 全文搜索可以同時對多個字段做索引,like只能對單一字段搜索

對于中文的分詞可能需要在理解語義的基礎上才能有效的分詞;比如上文中的 你好世界(hello world)對于英文按空格切分就可以,中文則需要理解語義的基礎才能分成 你好/世界。

這里分享一下python中jieba分詞,有助于理解中文分詞的魅力

結巴分詞利用一個中文詞庫,通過詞庫計算漢字之間構成詞語的關聯概率,所以通過計算漢字之間的概率,就可以形成分詞的結果。

In [1]: import jieba

In [2]: jieba.lcut("你好世界")
Building prefix dict from the default dictionary ...
Dumping model to file cache /var/folders/st/b16fyn3s57x_5vszjl599njw0000gn/T/jieba.cache
Loading model cost 0.937 seconds.
Prefix dict has been built successfully.
Out[2]: ['你好', '世界']

In [3]: jieba.lcut("hello world")
Out[3]: ['hello', ' ', 'world']

對于一般的項目mysql的全文索引可以解決80%的需求,它可以較為完美的支持中文的檢索、自動分詞、結果排序、組合查詢等功能;但性能應該是瓶頸,Elastissearch可以友好的實現全文檢索。

全文索引不能達到like的效果,連著的語句會因為分詞形成多個詞語。

參考資料

Mysql fulltext

以上就是MySQL 全文檢索的使用示例的詳細內容,更多關于MySQL 全文檢索的使用的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • Mysql實現全文檢索、關鍵詞跑分的方法實例
  • PHP+MySQL+sphinx+scws實現全文檢索功能詳解
  • mysql 全文檢索中文解決方法及實例代碼
  • 深度解析MySQL 5.7之中文全文檢索

標簽:南充 徐州 西寧 無錫 自貢 龍巖 麗水 迪慶

巨人網絡通訊聲明:本文標題《MySQL 全文檢索的使用示例》,本文關鍵詞  MySQL,全文檢索,的,使用,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL 全文檢索的使用示例》相關的同類信息!
  • 本頁收集關于MySQL 全文檢索的使用示例的相關信息資訊供網民參考!
  • 推薦文章
    午夜在线观看视频免费 成人| 九九精品在线播放| 成人高清免费| 四虎影视库国产精品一区| 国产一区二区福利久久| 黄色免费三级| 久久国产影院| 欧美大片aaaa一级毛片| 精品国产一区二区三区久久久蜜臀| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 91麻豆精品国产综合久久久| 国产成人精品影视| 国产极品精频在线观看| 青青久久精品| 国产成+人+综合+亚洲不卡| 亚洲天堂一区二区三区四区| 欧美激情一区二区三区视频| 二级片在线观看| 国产视频久久久| 亚洲精品中文字幕久久久久久| 你懂的福利视频| 国产成a人片在线观看视频| 国产91视频网| 精品视频一区二区三区免费| 国产网站免费观看| 黄色福利片| 一级女性大黄生活片免费| 国产a网| 欧美日本二区| 日韩一级精品视频在线观看| 成人高清护士在线播放| 精品在线视频播放| 毛片高清| 欧美国产日韩在线| 国产高清视频免费观看| 午夜欧美福利| 香蕉视频久久| 黄色免费三级| 久久精品免视看国产成人2021| 香蕉视频三级| 欧美一区二区三区性| 国产成人精品综合在线| 精品在线观看国产| 午夜欧美成人久久久久久| 久久福利影视| 欧美激情在线精品video| 欧美爱色| 麻豆污视频| 亚欧成人乱码一区二区| 亚洲天堂一区二区三区四区| 日本免费乱理伦片在线观看2018| 成人av在线播放| 精品视频在线观看一区二区| a级毛片免费观看网站| 国产视频久久久| 你懂的福利视频| 国产一区二区精品| 日韩中文字幕一区| 亚洲天堂在线播放| 精品在线观看国产| 国产亚洲精品aaa大片| 亚洲第一视频在线播放| 精品视频在线看| 欧美国产日韩一区二区三区| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 欧美激情在线精品video| 欧美1卡一卡二卡三新区| 九九精品在线| 国产韩国精品一区二区三区| 色综合久久天天综合绕观看| 色综合久久久久综合体桃花网| 亚洲第一色在线| 亚洲天堂在线播放| 亚洲天堂免费| 久久精品免视看国产成人2021| 日本伦理片网站| 国产国产人免费视频成69堂| 日韩中文字幕在线亚洲一区| 精品美女| 欧美国产日韩一区二区三区| 欧美a级片视频| 日本在线播放一区| 亚洲精品影院久久久久久| 韩国三级香港三级日本三级| 日韩专区第一页| 尤物视频网站在线观看| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 精品国产三级a| 国产一区二区精品尤物| 精品毛片视频| 欧美国产日韩久久久| 欧美爱色| 高清一级毛片一本到免费观看| 黄色福利| 深夜做爰性大片中文| 四虎精品在线观看| 欧美电影免费| 色综合久久久久综合体桃花网| 欧美1区| 91麻豆精品国产综合久久久| 久久99这里只有精品国产| 91麻豆爱豆果冻天美星空| 欧美另类videosbestsex高清| 成人免费一级毛片在线播放视频| 日韩av成人| 99色视频在线| 国产麻豆精品免费密入口| 成人免费一级毛片在线播放视频| 四虎影视久久久| 亚洲爆爽| 99久久网站| 国产福利免费视频| 国产91素人搭讪系列天堂| 欧美日本免费| 欧美国产日韩在线| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 精品国产一区二区三区精东影业 | 青青久久国产成人免费网站| 成人影视在线播放| 欧美一区二区三区性| 可以免费看毛片的网站| 可以免费看毛片的网站| 成人免费一级毛片在线播放视频| 久久福利影视| 999久久久免费精品国产牛牛| a级毛片免费观看网站| 韩国毛片免费大片| 黄视频网站免费看| 久久国产精品自由自在| 国产一区国产二区国产三区| 欧美激情一区二区三区视频高清| 韩国三级视频在线观看| 国产成人女人在线视频观看 | 久草免费在线观看| 久久国产精品永久免费网站| 欧美激情一区二区三区视频 | 日本在线www| 在线观看导航| 国产成人女人在线视频观看 | 国产一区二区精品久久91| a级黄色毛片免费播放视频| 亚欧乱色一区二区三区| 久草免费在线色站| 国产网站免费观看| 久草免费在线观看| 可以在线看黄的网站| 亚洲天堂一区二区三区四区| 欧美爱色| 欧美日本韩国| 久久精品免视看国产成人2021| 亚洲女人国产香蕉久久精品| 久久久成人影院| 青青久在线视频| 精品在线观看国产| 日日日夜夜操| 免费国产在线观看| 可以免费在线看黄的网站| 日韩中文字幕在线观看视频| 免费国产在线观看| 可以免费在线看黄的网站| 99久久精品国产高清一区二区| 麻豆污视频| 欧美日本韩国| 亚洲 欧美 91| 日本在线不卡视频| 青青青草影院| 亚欧成人毛片一区二区三区四区| 亚洲精品中文字幕久久久久久| 二级片在线观看| 99久久精品国产国产毛片| 色综合久久天天综合观看| 日韩在线观看视频免费| 尤物视频网站在线| 91麻豆精品国产片在线观看| 国产麻豆精品hdvideoss| 九九久久国产精品| 成人免费观看的视频黄页| 亚洲精品中文一区不卡| 一级女人毛片人一女人| 日本在线不卡免费视频一区| 久久久久久久久综合影视网| 午夜激情视频在线观看| 国产不卡福利| 久久99这里只有精品国产| 国产不卡精品一区二区三区| 亚洲精品中文字幕久久久久久| 欧美激情一区二区三区视频高清| 欧美国产日韩久久久| 九九免费高清在线观看视频| 天天做日日干| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 四虎影视库国产精品一区| 国产一级生活片| 欧美国产日韩在线| 韩国三级视频网站| 欧美激情一区二区三区视频| 日韩男人天堂| 高清一级片| 日本免费区| 999久久狠狠免费精品|