」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 為什麼「Harligt」和「Härligt」在 MySQL 中回傳相同的結果?看看排序規則和字元規範化。

為什麼「Harligt」和「Härligt」在 MySQL 中回傳相同的結果?看看排序規則和字元規範化。

發佈於2024-11-09
瀏覽:986

Why Does \

MySQL 對特殊字符的處理:悖論解釋

在MySQL 中,執行涉及特殊字符如'Å'、'Ä'的查詢,和「Ö」經常引發有關結果一致性的問題。例如,使用「Harligt」和「Härligt」進行查詢會產生相同的結果,這讓使用者感到困惑。

這種現象歸因於 MySQL 的預設排序規則設置,特別是“utf8_general_ci”和“utf8_unicode_ci”。這些排序規則透過將某些 unicode 字元(包括斯堪的納維亞字母)等同於其英語等效字元(例如“ä = A”)來規範化它們。此規範化簡化了比較操作和搜索,但在某些情況下可能會不方便。

要解決此問題,請考慮以下選項:

  • 使用不同的排序規則: 像「utf8_bin」這樣的排序規則保留字元值,包括特殊字符,但可能會對其他操作產生影響。
  • 在查詢中指定排序規則: 對於要覆寫預設排序規則的特定查詢,將「COLLATE utf8_bin」附加到查詢中。範例:
select * from topics where name='Harligt' COLLATE utf8_bin;
  • 建立自訂排序規則: 如果上述解決方案都都是如此解決方案都不是為了滿足您的需求,您可以建立適合您特定要求的自訂排序規則。

值得注意的是,如果沒有對特殊字元進行規範化,則無法執行 MySQL 中不區分大小寫的 LIKE 操作。不過,相關討論可以在這裡找到:

  • [Looking for case insensitive MySQL collat​​ion where "a" != "ä"](https://dba.stackexchange.com/questions /231116/尋找-case-insensitive-mysql-collat​​ion-where-a-a)
  • [MYSQL區分大小寫搜尋utf8_bin字段](https://stackoverflow.com/questions/9704962/mysql- case-sensitive-搜尋utf8-bin-field)
最新教學 更多>
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-11-16
  • Vite中環境變數的處理
    Vite中環境變數的處理
    在現代 Web 開發中,管理敏感資料(例如 API 金鑰、資料庫憑證以及不同環境的各種配置)至關重要。將這些變數直接儲存在程式碼中可能會帶來安全風險並使部署變得複雜。 Vite,一個現代的前端建構工具,提供了一種透過.env檔案管理環境變數的簡單方法。 什麼是 .env 檔? .env 檔案是一...
    程式設計 發佈於2024-11-16
  • 如何使用 Django REST Framework 高效處理嵌套序列化器中的外鍵分配?
    如何使用 Django REST Framework 高效處理嵌套序列化器中的外鍵分配?
    Django REST Framework 中的嵌套序列化器的外鍵分配Django REST Framework (DRF) 提供了一個管理外鍵關係的便捷方法序列化資料。然而,在嵌套序列化器中獲得所需的行為可能具有挑戰性。 嵌套序列化器中的外鍵分配嵌套序列化器繼承其父序列化器的行為。預設情況下,它們...
    程式設計 發佈於2024-11-16
  • 如何從 CodeIgniter URL 中刪除「index.php」?
    如何從 CodeIgniter URL 中刪除「index.php」?
    CodeIgniter .htaccess 和URL 重寫問題導航CodeIgniter 應用程式通常需要從URL 中刪除“index.php”,以允許使用者造訪具有更清晰語法的頁面。不過,新用戶在這個過程中可能會遇到困難。 刪除“index.php”的關鍵在於修改應用程式設定檔(applicati...
    程式設計 發佈於2024-11-16
  • 您可以在 `` 標籤內嵌套更多的 `` 元素嗎?
    您可以在 `` 標籤內嵌套更多的 `` 元素嗎?
    不常見的 HTML 結構: 可以容納 以外的標籤嗎? 在 HTML 世界中,嵌套標籤可以創建複雜的結構。然而,某些標籤的放置有時會受到限制。以神秘的 標籤為例,許多人認為它只能嵌套 元素。 深入研究:您的詢問源於探索標籤是否有效的願望除了 之外的其他人都可以在 中找到一個家。為了揭開這個概念的...
    程式設計 發佈於2024-11-16
  • 如何使用 XPath 條件選擇 XML 文件中的特定節點?
    如何使用 XPath 條件選擇 XML 文件中的特定節點?
    利用 XPath 條件選擇節點透過 XPath 導覽 XML 文件時,通常需要根據特定條件限制檢索的節點。在此範例中,我們的任務是根據日期屬性選擇性地檢索節點。 以下XPath 表達式從提供的XML 文件中擷取所有 節點:$nodes = $xml->xpath('//xml/events')...
    程式設計 發佈於2024-11-16
  • 為什麼「margin: auto」不能與絕對定位的元素一起使用?
    為什麼「margin: auto」不能與絕對定位的元素一起使用?
    了解絕對定位邊距自動問題當將“position:absolute”應用於具有“margin-left:auto”和“的元素時margin-right: auto”,您可能會注意到邊距似乎沒有效果。此行為不同於“位置:相對”,其中邊距按預期工作。為了理解這種差異,讓我們更深入地研究底層機制。 當一個元...
    程式設計 發佈於2024-11-16
  • Go 如何處理方法中的指標和值接收者?
    Go 如何處理方法中的指標和值接收者?
    Go 指標:接收者和值類型Go 指標:接收者和值類型在Go 中,指針對於理解物件導向程式設計和記憶體管理是必不可少的。在處理指標時,掌握方法中接收器類型之間的差異至關重要。 type Vertex struct { X, Y float64 } func (v *Vertex) Abs() ...
    程式設計 發佈於2024-11-16
  • 如何從 Python 中的字串清單建立多個變數?
    如何從 Python 中的字串清單建立多個變數?
    如何從字串清單建立多個變數? [重複]許多程式場景要求我們同時操作多個物件或變數。一個常見的挑戰是從字串列表建立多個變量,其中每個變數的名稱與列表中的對應元素相符。 在 Python 中,您可以使用字典理解來完成此操作:names = ['apple', 'orange', 'banana'] fr...
    程式設計 發佈於2024-11-16
  • 如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    在 PHP 中組合關聯數組在 PHP 中,將兩個關聯數組組合成一個數組是常見任務。考慮以下請求:問題描述:提供的代碼定義了兩個關聯數組,$array1和$array2。目標是建立一個新陣列 $array3,它合併兩個陣列中的所有鍵值對。 此外,提供的陣列具有唯一的 ID,而名稱可能重疊。要求是建構一...
    程式設計 發佈於2024-11-16
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-11-16
  • 外鍵可以引用多型關聯中的多個表嗎?
    外鍵可以引用多型關聯中的多個表嗎?
    多態外鍵:一個外鍵可以引用多個表嗎? 關聯式資料庫中外鍵的概念通常涉及指定確切的目標參考列應指向的表。然而,在處理多態關聯時,其中一個表與一組中的多個其他表有關係,就會出現問題:是否可以有一個可以引用這些表中任何一個表的外鍵? 答案:否在MySQL和PostgreSQL中,外鍵約束只能引用單一父表。...
    程式設計 發佈於2024-11-16
  • 如何以字串陣列的形式檢索 TypeScript 介面的鍵?
    如何以字串陣列的形式檢索 TypeScript 介面的鍵?
    以字串陣列的形式存取 Typescript 介面的按鍵簡介在 Typescript 中處理表格資料需要使用介面來定義列結構。為了有效地操作這些結構,通常需要以字串陣列的形式檢索這些介面的屬性名稱。 解決方案使用自訂轉換器自 Typescript 版本 2.4 起,自訂轉換器提供了一種從介面中提取金鑰...
    程式設計 發佈於2024-11-16
  • 如何在JPA中使用複合主鍵實現資料版本控制?
    如何在JPA中使用複合主鍵實現資料版本控制?
    使用JPA 進行複合主鍵處理資料版本控制需要能夠使用不同版本複製實體,因此創建複合主鍵至關重要實體的主鍵。 具有複合主鍵的實體定義In JPA,複合主鍵可以使用@EmbeddedId或@IdClass註解來定義。 使用@EmbeddedId為key,然後在實體中用@EmbeddedId註解:@Ent...
    程式設計 發佈於2024-11-16
  • 如何修復 Anchor CMS 安裝過程中的「未指定輸入檔」錯誤?
    如何修復 Anchor CMS 安裝過程中的「未指定輸入檔」錯誤?
    Anchor CMS 中的「未指定輸入檔案」錯誤故障排除安裝期間Anchor CMS 中的「未指定輸入檔案」錯誤是常見問題。本文旨在為該問題提供全面的解釋和解決方案。 該錯誤是由於伺服器上的 PHP 實作與 CMS 對 URL 處理的期望不符而產生的。通常,當託管提供者使用 PHP 的 CGI 實作...
    程式設計 發佈於2024-11-16

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3