InnoDB에서 전체 텍스트 검색 유사 기능을 활용할 수 있습니까?
여러 개의 LIKE 연산자를 사용하는 간단한 쿼리는 여러 검색 문자열을 검색할 때 비효율적일 수 있습니다. Sphinx와 같은 외부 도구를 사용하지 않고 InnoDB 테이블에서 이 문제를 해결하려면 MyISAM 전체 텍스트 테이블을 채택하여 InnoDB 테이블에 다시 인덱싱하는 것을 고려해 보십시오.
데이터베이스 스키마
InnoDB를 스토리지 엔진으로 사용하는 데이터베이스:
CREATE TABLE users (...) ENGINE=INNODB; CREATE TABLE forums (...) ENGINE=INNODB; CREATE TABLE threads ( forum_id SMALLINT UNSIGNED NOT NULL, thread_id INT UNSIGNED NOT NULL DEFAULT 0, user_id INT UNSIGNED NOT NULL, subject VARCHAR(255) NOT NULL, -- Desired search field created_date DATETIME NOT NULL, next_reply_id INT UNSIGNED NOT NULL DEFAULT 0, view_count INT UNSIGNED NOT NULL DEFAULT 0, PRIMARY KEY (forum_id, thread_id) -- Composite clustered PK index ) ENGINE=INNODB;
다음으로 다음을 사용하여 전체 텍스트 검색 테이블을 생성합니다. MyISAM:
CREATE TABLE threads_ft ( forum_id SMALLINT UNSIGNED NOT NULL, thread_id INT UNSIGNED NOT NULL DEFAULT 0, subject VARCHAR(255) NOT NULL, FULLTEXT (subject), -- Fulltext index on subject PRIMARY KEY (forum_id, thread_id) -- Composite non-clustered index ) ENGINE=MYISAM;
저장 프로시저 검색
마지막으로 전체 텍스트 검색을 위한 저장 프로시저를 만듭니다.
DROP PROCEDURE IF EXISTS ft_search_threads; DELIMITER # CREATE PROCEDURE ft_search_threads ( IN p_search VARCHAR(255) ) BEGIN SELECT t.*, f.title AS forum_title, u.username, MATCH(tft.subject) AGAINST (p_search IN BOOLEAN MODE) AS rank FROM threads_ft tft INNER JOIN threads t ON tft.forum_id = t.forum_id AND tft.thread_id = t.thread_id INNER JOIN forums f ON t.forum_id = f.forum_id INNER JOIN users u ON t.user_id = u.user_id WHERE MATCH(tft.subject) AGAINST (p_search IN BOOLEAN MODE) ORDER BY rank DESC LIMIT 100; END; CALL ft_search_threads('+innodb +clustered +index');
이러한 수정 사항을 사용하면 외부 솔루션에 의존하지 않고도 InnoDB 테이블에서 전문과 유사한 검색 기능을 효과적으로 구현할 수 있습니다.
위 내용은 InnoDB 테이블은 외부 도구 없이 전체 텍스트 검색 기능을 활용할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!