> 데이터 베이스 > MySQL 튜토리얼 > 효율적인 패턴 일치를 위해 SQL의 LIKE 및 IN 연산자를 결합할 수 있습니까?

효율적인 패턴 일치를 위해 SQL의 LIKE 및 IN 연산자를 결합할 수 있습니까?

Linda Hamilton
풀어 주다: 2024-11-14 21:53:02
원래의
527명이 탐색했습니다.

Can you combine SQL's LIKE and IN operators for efficient pattern matching?

향상된 패턴 일치를 위해 SQL LIKE 및 IN 절 결합

SQL에서 LIKE 연산자는 일반적으로 패턴 일치에 사용되며 다음을 가능하게 합니다. 지정된 패턴과 부분적으로 일치하는 행을 찾습니다. 반면에 IN 연산자를 사용하면 열의 값이 미리 정의된 집합 내의 요소와 일치하는지 확인할 수 있습니다. 그러나 이 두 연산자를 결합할 때 특정 제한 사항이 발생할 수 있습니다.

다음 시나리오를 고려하십시오.

질문: LIKE와 연산자를 결합하는 것이 가능합니까? 단일 쿼리에서 일련의 다른 문자열에 대해 열을 효율적으로 일치시키는 IN 절이 있습니까? 예:

SELECT * FROM tablename WHERE column IN ('M510%', 'M615%', 'M515%', 'M612%');
로그인 후 복사

목표: 문자열 배열을 반복하지 않고 여러 LIKE 표현식을 사용하여 패턴 일치를 달성합니다.

해결책 :

LIKE IN 구문은 명시적으로 지원되지 않지만 원하는 결과를 얻기 위한 대체 접근 방식이 있습니다.

1. 하위 문자열 및 IN 사용:

substring() 함수를 사용하여 열의 시작 부분에서 지정된 수의 문자를 추출한 다음 IN 연산자를 사용하여 추출된 하위 문자열이 일치하는지 확인할 수 있습니다. 제공된 문자열 중:

SELECT * FROM tablename WHERE substring(column,1,4) IN ('M510','M615','M515','M612')
로그인 후 복사

이 예에서 substring() 함수는 열의 처음 4개 문자를 추출하고 IN 절은 추출된 하위 문자열이 지정된 4개의 문자열 중 하나와 일치하는지 확인합니다.

2. CASE 및 WHEN 사용:

또 다른 접근 방식은 CASE 및 WHEN 문을 활용하여 여러 조건을 평가하는 것입니다.

SELECT * 
FROM tablename 
WHERE 
  CASE
    WHEN column LIKE 'M510%' THEN TRUE
    WHEN column LIKE 'M615%' THEN TRUE
    WHEN column LIKE 'M515%' THEN TRUE
    WHEN column LIKE 'M612%' THEN TRUE
    ELSE FALSE
  END;
로그인 후 복사

이 CASE 문은 각 조건을 순차적으로 평가합니다. 조건 중 하나라도 충족되면 쿼리는 해당 행을 반환합니다.

이러한 대체 접근 방식을 사용하면 패턴 일치와 IN 절의 편리함을 결합하여 보다 효율적이고 간결한 SQL 쿼리를 수행할 수 있습니다.

위 내용은 효율적인 패턴 일치를 위해 SQL의 LIKE 및 IN 연산자를 결합할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿