일치 조건이 다른 테이블 열의 하위 문자열을 포함하는 한 테이블의 열과 관련된 JOIN 작업을 어떻게 수행할 수 있습니까?
Oct 26, 2024 pm 06:29 PMSQL JOIN 내에서 LIKE 사용
SQL에서 JOIN 작업을 수행하려면 서로 다른 테이블의 열 간에 일치 조건을 지정해야 하는 경우가 많습니다. 이러한 조건 중 하나는 테이블 A의 열을 테이블 B의 열과 일치시키는 것입니다. 여기서 B열의 내용은 A열의 내용 앞이나 뒤에 달라질 수 있습니다. 이 시나리오에서는 LIKE 연산자를 사용해야 합니다.
이를 달성하려면 다음과 같은 몇 가지 옵션이 있습니다.
- INSTR 사용:
<code class="sql">SELECT * FROM TABLE a JOIN TABLE b ON INSTR(b.column, a.column) > 0</code>
여기서 INSTR()은 첫 번째 위치를 반환합니다. B열 내에서 A열의 값이 발생합니다. 일치하는 행은 위치가 0보다 큰 행입니다.
- LIKE 직접 사용:
<code class="sql">SELECT * FROM TABLE a JOIN TABLE b ON b.column LIKE '%'+ a.column +'%'</code>
이 방법은 A 열 값의 양쪽에 와일드카드를 추가하여 B 열 내에서 모든 문자가 이 값 앞이나 뒤에 올 수 있도록 합니다.
- CONCAT과 함께 LIKE 사용:
<code class="sql">SELECT * FROM TABLE a JOIN TABLE b ON b.column LIKE CONCAT('%', a.column ,'%')</code>
이전 접근 방식과 유사하게 이 방법은 CONCAT() 함수를 사용하여 A열 값의 양쪽에 와일드카드가 포함된 문자열을 구성합니다.
대소문자를 구분하지 않는 일치를 보장하려면 비교하기 전에 두 열을 모두 대문자로 변환하는 것이 좋습니다. 이는 UPPER() 함수를 사용하여 달성할 수 있습니다.
가장 효율적인 방법은 EXPLAIN 계획 출력을 검토하여 결정된 특정 데이터베이스 및 관련 데이터에 따라 달라집니다.
위 내용은 일치 조건이 다른 테이블 열의 하위 문자열을 포함하는 한 테이블의 열과 관련된 JOIN 작업을 어떻게 수행할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

인기 기사

인기 기사

뜨거운 기사 태그

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까?

MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다.

Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음)

일반적인 취약점 (SQL 주입, 무차별 적 공격)에 대해 MySQL을 어떻게 보호합니까?
