MySQL WHERE 절의 열 연결
이름과 성 열이 있는 데이터베이스 테이블에서 단일 검색 쿼리 수행 검색어는 어려울 수 있습니다. LIKE 연산자를 사용하여 각 열을 개별적으로 검색하면 특히 단일 단어 검색어를 사용할 때 광범위한 결과를 얻을 수 있습니다.
검색 결과의 범위를 좁히려면 CONCAT() 함수를 활용하여 첫 번째와 마지막을 연결할 수 있습니다. 단일 문자열로 이름을 지정합니다. 그런 다음 LIKE 연산자를 사용하여 이 문자열을 검색어와 비교할 수 있습니다. 그러나 질문에 제공된 예제 쿼리:
select * from table where first_name like '%$search_term%' or last_name like '%$search_term%' or concat_ws(' ',first_name,last_name) like '%$search_term%';
원하는 결과를 얻지 못하는 것 같습니다.
답변에서 제안된 쿼리의 단순화된 버전:
select * from table where concat_ws(' ',first_name,last_name) like '%$search_term%';
단일 쿼리로 전체 이름을 검색하는 목표를 달성해야 합니다. CONCAT() 함수는 이름과 성을 단일 문자열로 결합한 다음 LIKE 연산자를 사용하여 검색어와 비교합니다. 이 접근 방식은 보다 정확한 검색 결과를 제공해야 합니다.
원래 쿼리 문제를 해결하려면 예상대로 작동하지 않는 이름과 검색어의 예를 제공하는 것이 도움이 될 것입니다. 문제가 쿼리나 테이블 데이터의 다른 곳에 있을 수도 있습니다.
위 내용은 CONCAT()을 사용하여 MySQL에서 전체 이름을 효율적으로 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!