Skip to content

Zeroplex 生活隨筆

軟體開發、伺服器和生活瑣事

小 縮小字型大小。 中 重設字型大小。 大 放大字型大小。

在 MySQL 上查詢英文發音類似的文字

Posted on 2022 年 11 月 15 日2022 年 11 月 15 日 By 日落 在〈在 MySQL 上查詢英文發音類似的文字〉中尚無留言

MySQL 有個叫做 soundex() 的函式,這個函式會回傳字串發音的 fingerprint,藉由這個 fingerprint 來搜尋其他發音類似的字串。

先隨意挑幾個單字:

select soundex("depoart"), soundex("department")
+--------------------+-----------------------+
| soundex("depoart") | soundex("department") |
+--------------------+-----------------------+
| D163               | D16353                |
+--------------------+-----------------------+

depoart 和 department 在前半部有相同的發音,所以 soundex() 回傳的 prefix 是相同的。

如果換成一組完全不同的文字:

select soundex("space"), soundex("system")
+------------------+-------------------+
| soundex("space") | soundex("system") |
+------------------+-------------------+
| S120             | S350              |
+------------------+-------------------+

因為都是 s 開頭,所以回傳值都是 S,但後半部的值就不同了。

這個在查詢類似拼字錯誤上應該蠻有用的,像是:

select case 
    when  soundex("john") = soundex("jone")
    then 1 else 0
end
as familiar
+----------+
| familiar |
+----------+
| 1        |
+----------+
Tags:MySQL

文章導覽

Previous Post: 使用 Raspberry Pi 作為 lab 機的一些問題
Next Post: 第一次參加購物節就掉漆

發佈留言 取消回覆

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *


其他

關於我  (About me)

小額贊助

  文章 RSS Feed

  留言 RSS Feed

Apache AWS Bash C/C++ Docker FreeBSD GCP Git Google Java JavaScript Laravel Linux Microsoft MSSQL MySQL Nginx PHP PHPUnit PostgreSQL Python Qt Ubuntu Unix Vim Web Windows WordPress XD 作業系統 分享 好站推薦 專題 攝影 新奇搞笑 新聞 旅遊 生活雜記 程式設計 網路架站 網頁設計 資訊學習 資訊安全 遊戲 音樂


創用 CC 授權條款
本著作係採用創用 CC 姓名標示-相同方式分享 4.0 國際 授權條款授權.