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'
이 접근 방식은 다음을 달성합니다. 원하는 조건:
이러한 조건은 인덱스가 사용 중임을 나타냅니다.
보안 고려 사항:
준비된 명령문은 SQL 삽입 공격의 위험을 완화합니다. 그러나 2차 SQL 주입 공격을 방지하려면 사용자가 제공한 데이터를 삭제하는 것이 여전히 중요합니다.
위 내용은 MySQL의 FIND_IN_SET 또는 이에 상응하는 함수가 인덱스를 활용할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!