SQL Server 内の区切り文字列からのデータの抽出
SQL Server には、区切り文字で区切られた文字列を直接分割するための組み込み関数がありません。 ただし、回避策として PARSENAME
関数を利用できます。 この関数は通常、データベース オブジェクト名の解析に使用されますが、この目的に適合させることができます。
PARSENAME
関数は、ピリオド (.
) に基づいて文字列を分割することで機能します。他の区切り文字と併用するには、まず区切り文字をピリオドに置き換えます。 たとえば、スペース区切りの文字列から 2 番目の要素を抽出するには:
<code class="language-sql">SELECT PARSENAME(REPLACE('Hello John Smith', ' ', '.'), 2)</code>
このクエリは「John」を返します。 REPLACE
関数はスペースをピリオドに変更し、PARSENAME(..., 2)
で 2 番目の要素を抽出します。
PARSENAME の制限:
PARSENAME
メソッドには制限があります。 文字列にすでにピリオドが含まれている場合、このアプローチは失敗します。 また、これは限られた数の区切られた要素に対してのみ実用的です。
より堅牢なソリューション: ユーザー定義関数 (UDF)
より複雑なシナリオと信頼性の高い文字列分割の場合は、カスタム UDF をお勧めします。 適切に設計された UDF は、さまざまな区切り文字を処理し、多くのセグメントを含む文字列から要素を効率的に抽出できます。 これにより、PARSENAME
回避策と比較して、よりスケーラブルで保守可能なソリューションが提供されます。
以上がSQL Serverを使用して、区切り文字列内の特定のアイテムにアクセスするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。