MySQL에서 사전 정의된 목록을 기반으로 특정 값을 제외하는 쿼리를 구성하면 까다로워지세요. 이 질문은 제외된 값의 쉼표로 구분된 목록을 포함하도록 변수를 할당하고 이를 "NOT IN" 절에 사용하는 문제에 대해 자세히 설명합니다.
잘못된 변수 형식
질문에서 언급했듯이 다양한 형식으로 변수를 할당하는 데 실패하여 오류가 발생하거나 값이 무시되었습니다. 시도된 형식은 다음과 같습니다.
문제
문제는 "IN" 절이 쿼리에서 컴파일되는 방식에 있습니다. 변수를 사용하면 WHERE id_campo가 ('817,803,495')에 없는 단일 문자열로 컴파일됩니다. 그러나 "NOT IN" 절의 올바른 형식에는 별도의 값이 필요합니다: WHERE id_campo not in ('817','803','495').
해결책: FIND_IN_SET() 사용
이 문제를 극복하기 위해 MySQL은 FIND_IN_SET() 함수를 제공합니다. 변수에 정의된 목록을 기반으로 한 제외. 수정된 쿼리는 다음과 같습니다.
SET @idcamposexcluidos='817,803,495'; ... WHERE FIND_IN_SET(id_campo, @idcamposexcluidos) = 0
이 솔루션은 id_campo 값이 @idcamposexcluidos 변수의 값과 일치하는 행을 성공적으로 제외합니다.
참고: FIND_IN_SET()은 문제를 해결하고 id_campo에서 인덱스 사용을 방지합니다. 칼럼.
위 내용은 'NOT IN' 절에서 쉼표로 구분된 목록이 있는 MySQL 변수를 어떻게 사용할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!