SQL Server에서 마지막 문자 인덱스를 찾는 다른 방법
많은 개발자는 특히 특수 문자가 포함된 문자열을 처리할 때 SQL Server의 LastIndexOf 함수를 사용하여 문자열에서 특정 문자를 추출하는 데 어려움을 겪고 있습니다. 이 문제를 해결하기 위해 SQL Server 기본 제공 기능을 사용하여 몇 가지 대안을 살펴보겠습니다.
문자열 끝부터 문자 검색
지정된 구분 기호(예: "_") 뒤의 문자열 끝에서 문자를 검색하려면 다음 해결 방법을 사용할 수 있습니다.
<code class="language-sql">select right(db_name(), charindex('_', reverse(db_name()) + '_') - 1)</code>
이 쿼리는 RIGHT 함수를 사용하여 문자열의 오른쪽 끝에서 지정된 수의 문자를 검색하고 CHARINDEX를 사용하여 구분 기호의 인덱스를 결정합니다.
문자열의 시작 부분부터 문자 검색
또는 특정 구분 기호 앞의 문자를 검색해야 하는 경우 LEFT 함수를 사용할 수 있습니다.
<code class="language-sql">select left(db_name(), len(db_name()) - charindex('_', reverse(db_name()) + '_'))</code>
LEFT는 문자열 시작 부분부터 지정된 수의 문자를 반환하고, CHARINDEX는 다시 구분 기호의 인덱스를 찾습니다.
이러한 방법은 복잡한 문자열 반전 작업 없이 SQL Server의 문자열에서 문자를 추출하기 위한 보다 직접적이고 읽기 쉬운 솔루션을 제공합니다.
위 내용은 LastIndexOf를 사용하지 않고 SQL Server에서 마지막 문자 인덱스를 효율적으로 찾는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!