>데이터 베이스 >MySQL 튜토리얼 >'NOT IN' 절에서 쉼표로 구분된 목록이 있는 MySQL 변수를 어떻게 사용할 수 있습니까?

'NOT IN' 절에서 쉼표로 구분된 목록이 있는 MySQL 변수를 어떻게 사용할 수 있습니까?

DDD
DDD원래의
2025-01-04 06:11:43678검색

How Can I Use a MySQL Variable with a Comma-Separated List in a

"NOT IN" 쿼리에서 제외된 값 목록에 대한 MySQL 변수 설정

MySQL에서 사전 정의된 목록을 기반으로 특정 값을 제외하는 쿼리를 구성하면 까다로워지세요. 이 질문은 제외된 값의 쉼표로 구분된 목록을 포함하도록 변수를 할당하고 이를 "NOT IN" 절에 사용하는 문제에 대해 자세히 설명합니다.

잘못된 변수 형식

질문에서 언급했듯이 다양한 형식으로 변수를 할당하는 데 실패하여 오류가 발생하거나 값이 무시되었습니다. 시도된 형식은 다음과 같습니다.

  • SET @idcamposexcluidos='(817,803,495)';
  • SET @idcamposexcluidos=817,803,495;

문제

문제는 "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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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