「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > MySQL で部分文字列の 2 番目または 3 番目の出現を見つけるにはどうすればよいですか?

MySQL で部分文字列の 2 番目または 3 番目の出現を見つけるにはどうすればよいですか?

2024 年 11 月 19 日に公開
ブラウズ:277

How to Find the Second or Third Occurrence of a Substring in MySQL?

MySQL での部分文字列の 2 番目または 3 番目のインデックスの検索

データベース内の文字列を操作する場合、多くの場合、位置を特定する必要があります。特定の部分文字列の。単純な LIKE クエリでは不十分な場合は、その部分文字列の特定の出現箇所のインデックスを正確に識別する方法が必要になる場合があります。

問題:
スペースがあります-分割された文字列であり、相対位置に基づいて文字列の特定のセクションを抽出する必要があります。たとえば、文字列「AAAA BBBB CCCC DDDD EEE」が与えられた場合、部分文字列「CCCC」を抽出したいとします。

解決策:
MySQL には、SUBSTRING_INDEX という強力な関数が用意されています。より大きな文字列内で n 番目に出現する部分文字列を検索します。文字列内の 2 番目 (または 3 番目) のスペースを検索するには、ネストされた SUBSTRING_INDEX 呼び出しを利用できます。

SELECT SUBSTRING_INDEX(SUBSTRING_INDEX(field, ' ', 3), ' ', -1)
FROM table

上記のクエリでは、内部の SUBSTRING_INDEX 呼び出しによってフィールド列の 3 番目のスペースまでの部分文字列が抽出され、「AAAA BBBB CCCC」が得られます。次に、外側の SUBSTRING_INDEX 呼び出しによって、3 番目のスペースの後の部分文字列 (この場合は「CCCC」) が分離されます。

複数の SUBSTRING_INDEX 呼び出しをネストすることにより、その後に出現する区切り文字を引き続き識別し、目的の部分文字列を抽出できます。必要です。この多用途関数は、MySQL で複雑な文字列操作タスクを処理する便利で効率的な方法を提供します。

最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3