MySQL での部分文字列の 2 番目または 3 番目のインデックスの検索
データベース内の文字列を操作する場合、多くの場合、位置を特定する必要があります。特定の部分文字列の。単純な LIKE クエリでは不十分な場合は、その部分文字列の特定の出現箇所のインデックスを正確に識別する方法が必要になる場合があります。
問題:
スペースがあります。分割された文字列であり、相対位置に基づいて文字列の特定のセクションを抽出する必要があります。たとえば、文字列「AAAA BBBB CCCC DDDD EEE」がある場合、部分文字列「CCCC」を抽出したいとします。
解決策:
MySQL には、SUBSTRING_INDEX と呼ばれる強力な関数が用意されています。より大きな文字列内で n 番目に出現する部分文字列を見つけることができます。文字列内の 2 番目 (または 3 番目) のスペースを検索するには、ネストされた SUBSTRING_INDEX 呼び出しを利用できます。
<code class="sql">SELECT SUBSTRING_INDEX(SUBSTRING_INDEX(field, ' ', 3), ' ', -1) FROM table</code>
上記のクエリでは、内部の SUBSTRING_INDEX 呼び出しにより、フィールド列の 3 番目のスペースまでの部分文字列が抽出されます。 、「AAAA BBBB CCCC」を与えます。次に、外側の SUBSTRING_INDEX 呼び出しによって、3 番目のスペースの後の部分文字列 (この場合は「CCCC」) が分離されます。
複数の SUBSTRING_INDEX 呼び出しをネストすることにより、引き続き区切り文字の後続の出現を識別し、目的の部分文字列を抽出できます。必要です。この多用途関数は、MySQL で複雑な文字列操作タスクを処理する便利かつ効率的な方法を提供します。
以上がMySQL で部分文字列の 2 番目または 3 番目の出現を見つけるにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。