>데이터 베이스 >MySQL 튜토리얼 >'NOT IN' 절에 사용하기 위해 MySQL 변수의 형식을 올바르게 지정하는 방법은 무엇입니까?

'NOT IN' 절에 사용하기 위해 MySQL 변수의 형식을 올바르게 지정하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-31 20:32:10904검색

How to Correctly Format MySQL Variables for Use in a

"NOT IN" 값 목록에 대한 MySQL 변수 형식

"NOT IN" 목록을 사용하여 MySQL 쿼리에서 특정 값을 제외하려고 할 때 변수를 제외된 값으로 바꾸는 것이 편리한 솔루션이 될 수 있습니다. 그러나 올바른 변수 형식을 확인하는 것이 중요합니다.

귀하의 쿼리에 설명된 대로 '@idcamposexcluidos' 변수를 다른 형식으로 할당하려고 했습니다:

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

그러나 이러한 형식 중 어느 것도 예상대로 작동하지 않습니다. 그 이유는 "IN" 절에 단일 문자열이 아닌 별도의 값이 필요하기 때문입니다. 따라서 쿼리는

WHERE id_campo not in (@idcamposexcluidos)

사실상 다음과 같습니다.

WHERE id_campo not in ('817,803,495')

이는 잘못된 것입니다. 값은 별도의 문자열 리터럴로 제공되어야 합니다.

WHERE id_campo not in ('817','803','495')

이 문제를 해결하려면 두 가지 옵션이 있습니다.

  1. 동적 SQL: 쿼리 만들기 제외된 값의 연결을 동적으로 사용합니다.
  2. MySQL FIND_IN_SET() 함수: FIND_IN_SET() 함수를 사용하여 아래와 같이 쉼표로 구분된 제외 값 목록에 해당 값이 있는지 확인합니다.
SET @idcamposexcluidos='817,803,495';
...
WHERE FIND_IN_SET(id_campo, @idcamposexcluidos) = 0

FIND_IN_SET() 사용에 유의하세요. 기능을 사용하면 인덱스 사용이 저하될 수 있습니다.

위 내용은 'NOT IN' 절에 사용하기 위해 MySQL 변수의 형식을 올바르게 지정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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