>데이터 베이스 >MySQL 튜토리얼 >구분 기호가 누락된 T-SQL에서 문자열을 분할하는 방법은 무엇입니까?

구분 기호가 누락된 T-SQL에서 문자열을 분할하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-08 09:31:41661검색

How to Split Strings in T-SQL with Missing Delimiters?

T-SQL에서 구분 기호 기반 문자열 분할, 누락된 구분 기호 처리

T-SQL에서는 해당 구분 기호가 항상 존재하지 않는 경우에도 특정 구분 기호를 기준으로 문자열을 분할해야 할 수 있습니다. 이 작업은 일반적으로 SUBSTRING 함수를 사용하여 수행됩니다. 그러나 줄에 예상 구분 기호가 없으면 질문에 제공된 코드가 실패합니다.

이 문제를 해결하려면 다음 수정된 코드를 고려하세요.

<code class="language-sql">SELECT 
    CASE 
        WHEN CHARINDEX('/', myColumn) = 0 THEN myColumn
        ELSE SUBSTRING(myColumn, 1, CHARINDEX('/', myColumn) - 1)
    END AS FirstName,
    CASE 
        WHEN CHARINDEX('/', myColumn) = 0 THEN NULL
        ELSE SUBSTRING(myColumn, CHARINDEX('/', myColumn) + 1, LEN(myColumn))
    END AS LastName
FROM MyTable;</code>

이 코드에서는 CASE 문을 사용하여 FirstName 및 LastName 열의 하위 문자열이 시작하고 끝나는 위치를 결정합니다. FirstName 열의 시작 위치는 문자열의 시작 부분(구분 기호가 없는 경우) 또는 구분 기호 앞의 문자로 설정됩니다. 마찬가지로 FirstName 열의 끝 위치는 문자열 끝이나 구분 기호 앞의 문자로 설정됩니다.

이 방법을 사용하면 코드가 예상 구분 기호가 있는 줄뿐만 아니라 예상 구분 기호가 없는 줄도 오류 없이 처리할 수 있습니다. 결과 출력은 구분 기호가 없는 행의 경우에도 누락된 값이 NULL로 표시되는 필수 FirstName 및 LastName 값을 제공합니다. 이는 원래 코드보다 더 간결하고 효율적이며 누락된 구분 기호를 더 명확하게 처리합니다.

위 내용은 구분 기호가 누락된 T-SQL에서 문자열을 분할하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.