SQL의 'LIKE' 연산자 의미 체계를 사용하여 Java 비교기 구현
SQL에서 'LIKE' 연산자는 문자열 기반 일치에 널리 사용됩니다. 특정 패턴에 대해. Java에서 유사한 기능을 달성하기 위해 동일한 동작을 나타내는 사용자 정의 비교기를 만들 수 있습니다.
정규 표현식을 사용한 솔루션
Java의 정규 표현식을 사용하여 'LIKE' 연산자. 와일드카드 문자 '*'를 활용하면 모든 문자 시퀀스를 일치시킬 수 있습니다. 예를 들어, 다음 정규식은 'ital'이 포함된 모든 문자열과 일치합니다.
.*ital.*
마찬가지로 단일 문자 자리 표시자는 점('.')으로 표시될 수 있습니다. 따라서 아래 정규식은 'gi' 뒤에 'a'로 끝나는 단일 문자가 있는 모든 문자열과 일치합니다.
.*gi.a.*
리터럴 점과 일치하려면 슬래시를 사용하여 이스케이프 처리하세요.
\.
비교기 구현
정규식을 사용하여, 이제 SQL 'LIKE' 연산자처럼 동작하는 Java 비교기를 구현할 수 있습니다.
import java.util.Comparator; import java.util.regex.Pattern; public class LikeComparator implements Comparator<String> { @Override public int compare(String s1, String s2) { Pattern pattern = Pattern.compile(s2); return pattern.matcher(s1).matches() ? 0 : 1; } }
사용 예
비교기를 사용하려면 간단히 인스턴스화하고 비교하면 됩니다. '비교' 방법을 사용하는 문자열:
LikeComparator comparator = new LikeComparator(); System.out.println(comparator.compare("digital", "%ital%")); // true System.out.println(comparator.compare("digital", "%gi?a%")); // true System.out.println(comparator.compare("digital", "digi%")); // true System.out.println(comparator.compare("digital", "%cam%")); // false System.out.println(comparator.compare("digital", "tal%")); // false
위 내용은 SQL의 `LIKE` 연산자 기능을 사용하여 Java 비교기를 어떻게 구현할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!