>데이터 베이스 >SQL >SQL에서 like와 in의 사용법

SQL에서 like와 in의 사용법

下次还敢
下次还敢원래의
2024-05-02 03:39:171033검색

SQL에서 LIKE는 특정 패턴이 포함된 문자열을 찾는 데 사용됩니다. 와일드카드를 지원하지만 IN 연산자만큼 효율적이지는 않습니다. IN은 지정된 값 목록과 일치하는 필드를 찾는 데 사용되며 더 빠르고 인덱스 최적화를 지원합니다. 특정 값을 찾을 때는 IN을 사용하고, 유사한 문자열을 찾을 때는 LIKE를 사용하고, 성능을 최적화하려면 IN을 우선적으로 사용하는 것이 좋습니다.

SQL에서 like와 in의 사용법

SQL에서 LIKE 및 IN 사용법

LIKEIN은 모두 SQL에서 데이터를 필터링하는 데 사용되는 연산자이지만 사용법과 효과가 다릅니다.

LIKE 연산자는 지정된 패턴과 일치하는 문자열을 찾는 데 사용됩니다. 패턴에는 단일 또는 여러 문자를 나타내는 퍼센트 기호(%) 및 밑줄(_)과 같은 와일드카드 문자가 포함될 수 있습니다. 예:

<code class="sql">SELECT * FROM customers WHERE name LIKE '%John%';</code>

이렇게 하면 이름에 "John"이라는 문자열이 포함된 모든 고객 레코드가 반환됩니다.

IN 연산자는 지정된 값 목록과 일치하는 필드를 찾는 데 사용됩니다. 값 목록은 괄호 안에 표시됩니다. 예:

<code class="sql">SELECT * FROM customers WHERE id IN (1, 2, 3);</code>

이렇게 하면 ID 1, 2 또는 3의 고객 기록이 반환됩니다.

차이

  • 다양성: LIKE는 더 일반적이며 패턴과 일치하는 모든 문자열을 찾을 수 있는 반면, IN은 지정된 값 목록과만 일치할 수 있습니다.
  • 효율성: IN은 제한된 값 목록만 확인하면 되는 반면 LIKE는 전체 문자열을 스캔해야 하기 때문에 일반적으로 LIKE보다 더 효율적입니다.
  • 인덱스: 필드에 인덱스가 구축된 경우 IN은 인덱스를 사용하여 쿼리 성능을 향상시킬 수 있지만 LIKE는 그렇지 않습니다.
  • 와일드카드: LIKE는 와일드카드를 지원하지만 IN은 지원하지 않습니다.

사용 제안

  • 특정 값 찾기: IN을 사용하세요.
  • 비슷한 문자열 찾기: LIKE를 사용하세요.
  • 성능 최적화: 필드에 인덱스가 있는 경우 IN이 선호됩니다.

이름이 "John" 또는 "Jane"인 고객 찾기:

<code class="sql">SELECT * FROM customers WHERE name IN ('John', 'Jane');</code>

이름에 "smith" 문자열이 있는 고객 찾기:

<code class="sql">SELECT * FROM customers WHERE name LIKE '%smith%';</code>

위 내용은 SQL에서 like와 in의 사용법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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