집 >데이터 베이스 >MySQL 튜토리얼 >구분 기호가 누락된 T-SQL에서 문자열을 분할하는 방법은 무엇입니까?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!