MySQL 文字セットの文字マッピング
MySQL では、utf8_general_ci や utf8_unicode_ci を含む多くの Unicode 照合順序のデフォルトの動作は、文字を次のようにマップします。 「åäö」などの発音記号を、「aao」などの発音記号のない基本文字に追加します。これは、発音区別文字を使用したクエリが必ずしも予期した結果を生成するとは限らないことを意味します。
この動作は、ターミナルと PHP コンテキストの両方のクエリに影響します。これは、MySQL で使用される特定の文字エンコーディングと照合規則から生じます。
マッピングの理由
発音区別符号の基本文字へのマッピングは、より一般的で一貫した検索エクスペリエンス。発音記号の有無にかかわらず文字を同等のものとして扱うことにより、データベースはユーザーの幅広いクエリを満たす結果を返すことができます。
マッピングの無効化
無効にしたい場合は、このマッピングを使用し、発音区別符号を保持しながら大文字と小文字を区別した検索を実行するには、次の方法を使用できます。
特定のクエリの照合順序を指定する:
クエリを実行するとき、COLLATE キーワードを使用して照合順序を明示的に指定できます。 。たとえば、次のクエリを使用して発音記号を保持できます。
<code class="sql">select * from topics where name COLLATE utf8_bin = 'Harligt';</code>
Alternatives
大文字と小文字を区別せずに検索する必要がある場合は、ウムラウト変換を行う場合は、ASCII_WS トークナイザーでフルテキスト インデックスを使用することを検討してください。このトークナイザーは句読点と発音記号を無視し、大文字と小文字を区別しない効率的な検索を可能にします。
結論
MySQL による発音記号のある文字の処理は、検索クエリの動作に影響を与える可能性があります。デフォルトのマッピング ルールを理解し、適切な照合オプションを選択することは、クエリが意図した検索条件を正確に反映するために重要です。
以上がMySQL は文字セットと照合順序で発音記号をどのように処理しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。