Microsoft SQL Server 提供「不區分重音符號」的排序規則,允許執行類似 SELECT * FROM users WHERE name LIKE 'João'
的查詢,以檢索名稱為「Joao」的行。
PostgreSQL 提供 unaccent 模組,該模組可去除字串中的變音符號。要使用它,請安裝擴充功能並使用 unaccent()
函數:
<code class="language-sql">SELECT * FROM users WHERE unaccent(name) = unaccent('João');</code>
為了加快查詢速度,請建立表達式索引:
<code class="language-sql">CREATE INDEX users_unaccent_name_idx ON users(unaccent(name));</code>
請記住為安全起見限定函數和字典的模式:
<code class="language-sql">CREATE OR REPLACE FUNCTION public.f_unaccent(text) RETURNS text LANGUAGE sql IMMUTABLE PARALLEL SAFE STRICT AS $func$ SELECT public.immutable_unaccent('public.unaccent', ) -- 限定函数和字典的模式 $func$; CREATE INDEX users_unaccent_name_idx ON users(public.f_unaccent(name));</code>
在 PostgreSQL 9.6 及更高版本中,unaccent()
會正確展開連字,將“Œ”轉換為“OE”,將“ß”轉換為“ss”。
將 unaccent
與 pg_trgm
模組結合使用,可以使用 LIKE
或 ILIKE
進行任意模式匹配,並建立一個三元組 GIN 或 GIST 表達式索引。
為簡單起見,請考慮對左錨定模式使用三元組索引。
以上是如何在 PostgreSQL 中執行不區分重音的查詢?的詳細內容。更多資訊請關注PHP中文網其他相關文章!