MySQL單詞搜尋相關度排名
一個單詞搜尋的相關度排名,這個例子演示了一個單詞搜尋的相關度排名計算。
mysql> CREATE TABLE articles ( -> id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY, -> title VARCHAR(200), -> body TEXT, -> FULLTEXT (title,body) -> ) ENGINE=InnoDB; Query OK, 0 rows affected (0.56 sec) mysql> INSERT INTO articles (title,body) VALUES -> ('MySQL Tutorial','This database tutorial ...'), -> ("How To Use MySQL",'After you went through a ...'), -> ('Optimizing Your Database','In this database tutorial ...'), -> ('MySQL vs. YourSQL','When comparing databases ...'), -> ('MySQL Security','When configured properly, MySQL ...'), -> ('Database, Database, Database','database database database'), -> ('1001 MySQL Tricks','1. Never run mysqld as root. 2. ...'), -> ('MySQL Full-Text Indexes', 'MySQL fulltext indexes use a ..'); Query OK, 8 rows affected (0.02 sec) Records: 8 Duplicates: 0 Warnings: 0 mysql> SELECT id, title, body, MATCH (title,body) AGAINST ('database' IN BOOLEAN MODE) AS score FROM articles ORDER BY score DESC; +----+------------------------------+-------------------------------------+---------------------+ | id | title | body | score | +----+------------------------------+-------------------------------------+---------------------+ | 6 | Database, Database, Database | database database database | 1.0886961221694946 | | 3 | Optimizing Your Database | In this database tutorial ... | 0.36289870738983154 | | 1 | MySQL Tutorial | This database tutorial ... | 0.18144935369491577 | | 2 | How To Use MySQL | After you went through a ... | 0 | | 4 | MySQL vs. YourSQL | When comparing databases ... | 0 | | 5 | MySQL Security | When configured properly, MySQL ... | 0 | | 7 | 1001 MySQL Tricks | 1. Never run mysqld as root. 2. ... | 0 | | 8 | MySQL Full-Text Indexes | MySQL fulltext indexes use a .. | 0 | +----+------------------------------+-------------------------------------+---------------------+ 8 rows in set (0.00 sec)
總共有8條記錄,其中3條與資料庫搜尋詞匹配。第一條記錄(id 6)包含搜尋詞6次,相關度排名為1.0886961221694946。這個排名值計算使用TF的價值6(資料庫搜尋詞出現6次記錄id 6)和IDF值為0.42596873216370745,計算如下(8是記錄的總數和3是包含搜尋詞的記錄數量)
${IDF} = log10( 8 / 3 ) = 0.42596873216370745 mysql> select log10( 8 / 3 ) ; +---------------------+ | log10( 8 / 3 ) | +---------------------+ | 0.42596873216370745 | +---------------------+ 1 row in set (0.00 sec)
然後將TF和IDF值輸入到排名公式中
${rank} = ${TF} * ${IDF} * ${IDF}
在MySQL命令列客戶端執行計算將返回一個排名值1.088696164686938。
mysql> SELECT 6*log10(8/3)*log10(8/3); +-------------------------+ | 6*log10(8/3)*log10(8/3) | +-------------------------+ | 1.088696164686938 | +-------------------------+ 1 row in set (0.00 sec)
您可能會注意到SELECT ... MATCH ... AGAINST語句和MySQL命令列客戶端所計算的排名值有差別(1.0886961221694946對1.088696164686938)。區別在於InnoDB內部是如何執行整數和浮點數/雙精度型別轉換的(以及相關的精度和四舍五的決定),以及它們在其他地方是如何執行的,比如在MySQL命令列客戶端或其他型別的計算器中。
多詞搜尋的相關度排名
這個示例演示了基於前面示例中使用的articles表和資料計算多單詞全文搜尋的相關度排名。
如果你搜尋的是一個以上的單詞,那麼相關度排名值就是每個單詞相關度排名值的總和,如下公式所示:
${rank} = ${TF} * ${IDF} * ${IDF} + ${TF} * ${IDF} * ${IDF}
執行兩個搜尋詞('mysql tutorial')搜尋將返回以下結果:
mysql> SELECT id, title, body, MATCH (title,body) AGAINST ('mysql tutorial' IN BOOLEAN MODE) AS score FROM articles ORDER BY score DESC; +----+------------------------------+-------------------------------------+----------------------+ | id | title | body | score | +----+------------------------------+-------------------------------------+----------------------+ | 1 | MySQL Tutorial | This database tutorial ... | 0.7405621409416199 | | 3 | Optimizing Your Database | In this database tutorial ... | 0.3624762296676636 | | 5 | MySQL Security | When configured properly, MySQL ... | 0.031219376251101494 | | 8 | MySQL Full-Text Indexes | MySQL fulltext indexes use a .. | 0.031219376251101494 | | 2 | How To Use MySQL | After you went through a ... | 0.015609688125550747 | | 4 | MySQL vs. YourSQL | When comparing databases ... | 0.015609688125550747 | | 7 | 1001 MySQL Tricks | 1. Never run mysqld as root. 2. ... | 0.015609688125550747 | | 6 | Database, Database, Database | database database database | 0 | +----+------------------------------+-------------------------------------+----------------------+ 8 rows in set (0.00 sec)
在第一條記錄(id 1)中,“mysql”出現一次,“tutorial”出現兩次。“mysql”有六條匹配記錄,“tutorial”有兩條匹配記錄。當將這些值插入到用於多個單詞搜尋的排名公式中時,MySQL命令列客戶端返回預期的排名值
mysql> SELECT (1*log10(8/6)*log10(8/6)) + (2*log10(8/2)*log10(8/2)); +-------------------------------------------------------+ | (1*log10(8/6)*log10(8/6)) + (2*log10(8/2)*log10(8/2)) | +-------------------------------------------------------+ | 0.7405621541938003 | +-------------------------------------------------------+ 1 row in set (0.00 sec)
與單個單詞搜尋一樣,使用select ... match ... against語句和MySQL命令列工具執行的結果有差別。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/26015009/viewspace-2750304/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 單詞搜尋
- 79. 單詞搜尋
- 單詞搜尋問題
- LeetCode-079-單詞搜尋LeetCode
- 語義搜尋相關配置
- data.ai:2021年App Store搜尋關鍵詞熱度榜AIAPP
- [LeetCode題解]79. 單詞搜尋LeetCode
- BM42:語義搜尋與關鍵詞搜尋結合
- 語音技術——關鍵詞搜尋
- 【Leetcode 346/700】79. 單詞搜尋 【中等】【回溯深度搜尋JavaScript版】LeetCodeJavaScript
- 搜尋引擎es-分詞與搜尋分詞
- CSS 實現搜尋相關互動CSS
- bing/google/百度高階搜尋技巧--搜尋時關鍵詞不拆分,僅搜尋某個站點或僅要求pdf/doc格式搜尋結果等等Go
- 百度搜尋大資料:海外疫情持續擴散 “回國”相關內容搜尋熱度飆升100%大資料
- Elasticsearch 使用不同分詞器導致搜尋排名的問題Elasticsearch分詞
- 百度Java出現:“現在學java的都是傻子”相關搜尋!Java
- 自然搜尋排名該如何提高?
- 語音搜尋排名因素分析
- 百度簡單搜尋PC版玩法攻略 簡單搜尋有電腦版嗎?
- 網站最佳化搜尋引擎與關鍵詞網站
- 微信小程式實現搜尋關鍵詞高亮微信小程式
- 49_初識搜尋引擎_filter與query深入對比解密:相關度,效能Filter解密
- 【python】百度關鍵詞排名查詢實現Python
- [外掛擴充套件]百度關鍵詞排名套件
- 怎樣做好搜尋下拉最佳化?百度搜尋推薦詞的推廣方式
- solr搜尋分詞優化Solr分詞優化
- 小程式搜尋自定義關鍵詞功能關閉意欲何為?
- grep 命令系列:使用 grep 命令來搜尋多個單詞
- 淘寶API介面:獲得關鍵詞搜尋推薦API
- 廣度優先搜尋相關面試演算法總結(非圖論方面)面試演算法圖論
- ES 筆記十八:搜尋的相關性算分筆記
- 如何利用百度權重來提高關鍵詞排名?
- 百度搜尋引擎排名規則都有哪一些?
- 古詩詞相關詞庫
- 程式設計師 SEO 系列:如何找到更多搜尋關鍵詞?程式設計師
- 搜尋關鍵詞優化 助力全網霸屏營銷優化
- 55_初識搜尋引擎_相關度評分TF&IDF演算法獨家解密演算法解密
- Google:2020年美國搜尋詞榜單 “新冠”高居榜首Go