>데이터 베이스 >MySQL 튜토리얼 >MySQL의 FIND_IN_SET 또는 이에 상응하는 함수가 인덱스를 활용할 수 있습니까?

MySQL의 FIND_IN_SET 또는 이에 상응하는 함수가 인덱스를 활용할 수 있습니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-05 21:22:02205검색

Can MySQL's FIND_IN_SET or an Equivalent Function Utilize Indices?

MySQL FIND_IN_SET 또는 이에 상응하는 활용 지수를 사용할 수 있습니까?

쿼리 SELECT * FROM Foo WHERE FIND_IN_SET(id, '2,3') 기본 키 인덱스를 활용하지 않습니다. 이는 EXPLAIN 출력을 인덱스를 활용하는 SELECT * FROM FROM WHERE id IN (2,3)의 출력과 비교할 때 분명합니다.

목표: 다음과 같이 작동하는 저장 프로시저를 구성합니다. 두 번째 쿼리와 마찬가지로, 쉼표로 구분된 문자열을 포함하는 사전 지식 없이 인덱스를 활용합니다. ID.

해결책:

문자열을 매개변수로 받아들이는 준비된 문을 만듭니다.

CREATE PROCEDURE my_sp(@id_string NCHAR(1000))

그런 다음 준비된 문을 실행할 수 있습니다. 쉼표로 구분된 문자열을 인수로 사용:

EXEC my_sp '2,3'

이 접근 방식은 다음을 달성합니다. 원하는 조건:

  • 유형이 범위(ALL 아님)
  • 키가 NULL이 아님

이러한 조건은 인덱스가 사용 중임을 나타냅니다.

보안 고려 사항:

준비된 명령문은 SQL 삽입 공격의 위험을 완화합니다. 그러나 2차 SQL 주입 공격을 방지하려면 사용자가 제공한 데이터를 삭제하는 것이 여전히 중요합니다.

위 내용은 MySQL의 FIND_IN_SET 또는 이에 상응하는 함수가 인덱스를 활용할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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