ホームページ > データベース > mysql チュートリアル > Oracle SQL で最も遠い区切り文字の位置に基づいて文字列を分割するにはどうすればよいですか?

Oracle SQL で最も遠い区切り文字の位置に基づいて文字列を分割するにはどうすればよいですか?

Linda Hamilton
リリース: 2025-01-06 00:50:40
オリジナル
776 人が閲覧しました

How Can I Split a String in Oracle SQL Based on the Furthest Delimiter's Position?

Oracle SQL の区切り文字の位置による文字列の分割

Oracle SQL の INSTR 関数を使用すると、区切り文字の特定の位置に基づいて文字列を分割できます。これは、文字列の特定の部分を抽出する必要がある場合に特に便利です。たとえば、文字列「F/P/O」について考えてみましょう。この文字列を最も遠い区切り文字で分割する場合、予期される結果は「F/P」と「O」です。

Oracle SQL を使用してこれを実現するには、次のステートメントを利用できます。

SELECT
  SUBSTR(str, 1, INSTR(str, '/', -1, 1) - 1) AS part1,
  SUBSTR(str, INSTR(str, '/', -1, 1) + 1) AS part2
FROM data
ログイン後にコピー

このステートメントは、INSTR の負の start_position を利用して文字列の末尾から逆算し、最も遠い区切り文字を見つけます。次に、SUBSTR 関数を使用して、区切り文字の前後の部分文字列を抽出します。

予期しない結果への対処

最初のクエリでは、次の理由により予期しない結果が発生した可能性があります。 INSTR 呼び出しで start_position が省略される可能性があります。 start_position を負の値に調整すると、関数は文字列の末尾から最も遠い区切り文字を検索します。

以上がOracle SQL で最も遠い区切り文字の位置に基づいて文字列を分割するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート