日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

MySQL 全文檢索的使用示例

瀏覽:229日期:2023-10-02 07:51:14
目錄1. 環(huán)境準(zhǔn)備2. 數(shù)據(jù)準(zhǔn)備3. 開始表演4. 分詞引擎總結(jié)參考資料1. 環(huán)境準(zhǔn)備

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

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

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

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

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

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

n=1: ’你’, ’好’, ’世’, ’界’ n=2: ’你好’, ’好世’, ’世界’ n=3: ’你好世’, ’好世界’ n=4: ’你好世界’

# /etc/mysql/mysql.conf.d/mysqld.cnfft_min_word_len = 2ngram_token_size = 2# 如果沒有則新增配置echo ’ft_min_word_len = 2ngram_token_size = 2’ >> mysqld.cnf# 重啟服務(wù)/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. 數(shù)據(jù)準(zhǔn)備

-- mysql 于全文檢索的demomysql> CREATE TABLE `articles` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `title` varchar(50) DEFAULT NULL COMMENT ’主題’, `content` longtext NOT NULL COMMENT ’內(nèi)容’, 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(’如果’,’今生今世 永不再將你想起 除了除了在有些個因落淚而濕潤的夜里 如果如果你愿意’),(’愛情’,’有一天路標(biāo)遷了希望你能從容有一天橋墩斷了希望你能渡越有一天棟梁倒了希望你能堅強(qiáng)有一天期待蔫了希望你能理解’),(’遠(yuǎn)和近’,’你 一會看我一會看云我覺得你看我時很遠(yuǎn)你看云時很近’),(’斷章’,’你站在橋上看風(fēng)景,看風(fēng)景人在樓上看你。明月裝飾了你的窗子,你裝飾了別人的夢。’),(’獨語’,’我向你傾吐思念你如石像沉默不應(yīng)如果沉默是你的悲抑你知道這悲抑最傷我心’);Query OK, 5 rows affected (0.08 sec)Records: 5 Duplicates: 0 Warnings: 0 mysql> SELECT * from articles where match(content, title) against(’風(fēng)景’ in NATURAL LANGUAGE MODE) LIMIT 10;+----+--------+--------------------------------------------------------------------------------------------------------------------------+| id | title | content |+----+--------+--------------------------------------------------------------------------------------------------------------------------+| 10 | 斷章 | 你站在橋上看風(fēng)景,看風(fēng)景人在樓上看你。明月裝飾了你的窗子,你裝飾了別人的夢。 |+----+--------+--------------------------------------------------------------------------------------------------------------------------+1 row in set (0.02 sec)3. 開始表演 自然語言模式(NATURAL LANGUAGE MODE)

自然語言模式是MySQL 默認(rèn)的全文檢索模式。自然語言模式不能使用操作符,不能指定關(guān)鍵詞必須出現(xiàn)或者必須不能出現(xiàn)等復(fù)雜查詢。

布隆模式(BOOLEAN MODE)

BOOLEAN模式可以使用操作符,可以支持指定關(guān)鍵詞必須出現(xiàn)或者必須不能出現(xiàn)或者關(guān)鍵詞的權(quán)重高還是低等復(fù)雜查詢。

查詢擴(kuò)展(QUERY EXPANSION)

查詢的結(jié)果不僅匹配出結(jié)果同時可以聯(lián)想出其他你需要的結(jié)果。(類似關(guān)聯(lián)查詢,但是官網(wǎng)推薦僅支持短語查詢 否則會出現(xiàn)很多臟數(shù)據(jù))

-- 自然語言模式(NATURAL LANGUAGE MODE)查詢并得到評分mysql> SELECT id, title, MATCH ( content, title ) against ( ’風(fēng)景’ IN NATURAL LANGUAGE MODE ) AS score FROM articles;+----+-----------+--------------------+| id | title | score |+----+-----------+--------------------+| 7 | 如果 | 0 || 8 | 愛情 | 0 || 9 | 遠(yuǎn)和近 | 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 ( ’+風(fēng)景 -愛情’ IN BOOLEAN MODE );+----+--------+| id | title |+----+--------+| 10 | 斷章 |+----+--------+1 row in set (0.01 sec)-- 查詢擴(kuò)展(QUERY EXPANSION) 可以聯(lián)想出其他結(jié)果 mysql> SELECT id, title FROM articles where MATCH ( content, title ) against ( ’風(fēng)景’ WITH QUERY EXPANSION );+----+--------+| id | title |+----+--------+| 10 | 斷章 || 11 | 獨語 |+----+--------+2 rows in set (0.02 sec) 4. 分詞引擎

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

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

總結(jié)

優(yōu)點

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

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

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

結(jié)巴分詞利用一個中文詞庫,通過詞庫計算漢字之間構(gòu)成詞語的關(guān)聯(lián)概率,所以通過計算漢字之間的概率,就可以形成分詞的結(jié)果。

In [1]: import jiebaIn [2]: jieba.lcut('你好世界')Building prefix dict from the default dictionary ...Dumping model to file cache /var/folders/st/b16fyn3s57x_5vszjl599njw0000gn/T/jieba.cacheLoading 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%的需求,它可以較為完美的支持中文的檢索、自動分詞、結(jié)果排序、組合查詢等功能;但性能應(yīng)該是瓶頸,Elastissearch可以友好的實現(xiàn)全文檢索。

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

參考資料

Mysql fulltext

以上就是MySQL 全文檢索的使用示例的詳細(xì)內(nèi)容,更多關(guān)于MySQL 全文檢索的使用的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
精品成av人一区二区三区| 首页国产欧美日韩丝袜| 美女精品视频在线| 在线国产一区| 久久毛片亚洲| 国产麻豆精品久久| 男人操女人的视频在线观看欧美| 国产极品一区| 欧美福利一区| 亚洲va中文在线播放免费| 日韩成人av影视| 日韩亚洲国产欧美| 欧美精品资源| 麻豆国产一区| 日本在线成人| 性一交一乱一区二区洋洋av| 国产精品国产三级在线观看| 久久久久一区| 国产三级一区| 久久99伊人| 久久精品不卡| 91精品啪在线观看国产18| 欧美精品二区| 日韩三级精品| 亚洲精品九九| 亚洲区欧美区| 日韩在线一二三区| 亚洲欧洲一区二区天堂久久| 国产精品色在线网站| 久久亚洲精品伦理| 午夜久久99| 国产精品99免费看| 99精品在线| 少妇久久久久| 91嫩草亚洲精品| av中文字幕在线观看第一页| 日韩在线网址| 亚洲97av| 亚洲一区二区日韩| 美女网站久久| 日韩中文字幕91| 首页亚洲欧美制服丝腿| 亚洲在线国产日韩欧美| 1024精品久久久久久久久| 涩涩av在线| 亚洲高清不卡| 午夜在线视频观看日韩17c| 国产精品嫩草99av在线| 国产一区日韩一区| 99国产一区| 亚洲精品国产精品粉嫩| 日韩精品视频在线看| 免费精品视频在线| 中文久久精品| 一区二区三区四区精品视频| 精品在线91| 九九综合在线| 一二三区精品| 国产欧美日韩精品一区二区三区| 欧美亚洲色图校园春色| 亚洲免费专区| 国产三级一区| 成人午夜毛片| 亚洲香蕉网站| 视频在线观看国产精品| 夜夜嗨一区二区三区| 午夜精品影院| 亚洲2区在线| 国产剧情一区| sm捆绑调教国产免费网站在线观看 | 精品在线网站观看| 岛国av免费在线观看| 日韩中文在线播放| 国产精品日本| 国产精品流白浆在线观看| 精品资源在线| 99久久久久| 亚洲a级精品| 成人午夜网址| 亚洲欧美视频| 日韩av电影一区| 中文字幕高清在线播放| 午夜欧美精品久久久久久久| 婷婷丁香综合| 日韩国产欧美在线视频| 久久精品72免费观看| 国产伦精品一区二区三区千人斩 | 亚洲一区日本| 久久狠狠久久| 国产一区日韩| 日韩一区二区三区在线免费观看| 极品日韩av| 亚洲欧洲国产精品一区| 国产精品mv在线观看| 日韩欧美字幕| 日韩国产一二三区| 日韩成人三级| 日本aⅴ亚洲精品中文乱码| 精品视频网站| 在线视频观看日韩| 中文无码久久精品| 国产情侣一区在线| 亚洲欧美综合| 国产美女久久| 午夜欧美精品久久久久久久| 亚洲大全视频| 日韩av中文字幕一区| 亚洲国产欧美日本视频| 亚洲欧美日韩国产一区| 婷婷亚洲成人| 久久久精品久久久久久96 | 成人在线超碰| 亚洲精品伦理| 欧美午夜精品一区二区三区电影| 亚洲精品看片| 亚洲高清av| 国产毛片精品久久| 亚洲精品1区| 青青青免费在线视频| 亚洲欧美专区| 亚洲高清二区| 超级白嫩亚洲国产第一| 蜜桃av一区二区三区电影| 水蜜桃精品av一区二区| 丝袜美腿亚洲色图| 最近高清中文在线字幕在线观看1| 欧美专区在线| 日韩三区免费| 久久精品国内一区二区三区| 一区在线免费观看| 欧美精品91| 久久午夜精品| 91精品一区国产高清在线gif| 日本成人中文字幕| 性一交一乱一区二区洋洋av| 国产精品一区亚洲| 蜜臀国产一区二区三区在线播放| 国产一区二区三区亚洲| 亚欧成人精品| 91久久中文| 老牛影视精品| 久久三级毛片| 欧美精品观看| 亚洲日产国产精品| 激情偷拍久久| 91精品啪在线观看国产18 | 欧美日韩在线观看视频小说| 91午夜精品| 亚洲乱码久久| 一区二区三区四区在线观看国产日韩| 黄色成人91| 国产v综合v| 日韩免费久久| 日韩免费福利视频| 91亚洲一区| 国产盗摄——sm在线视频| 日韩成人午夜精品| 亚洲免费专区| 一区二区不卡| 日韩午夜精品| 国产毛片一区| 亚洲欧美日本日韩| 另类亚洲自拍| 蜜乳av另类精品一区二区| 亚洲午夜电影| 91精品在线观看国产| 国产精品1区在线| 国产精品chinese| 国产精品调教| 欧美亚洲tv| 国产精品一线天粉嫩av| 日本视频中文字幕一区二区三区| 亚洲人成亚洲精品| 日本欧美在线看| 亚洲成人日韩| 日韩视频在线一区二区三区| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 亚洲精品日本| 日韩高清三区| 国产欧美自拍一区| 久久精品国产网站| 国产成人a视频高清在线观看| 精品久久久网| 久久影院午夜精品| 亚洲激情二区| 国产精品v一区二区三区| 成人精品高清在线视频| 日韩伦理福利| 婷婷精品在线| 日韩大片在线播放| 日韩精品中文字幕一区二区| 国产日韩欧美高清免费| 欧美男人天堂| 在线精品国产亚洲| 97精品国产| 日韩av一区二| 激情自拍一区| 免费看一区二区三区| 免费av一区| 老司机免费视频一区二区三区|