From 21a3f16d9461188f06cb13624038684226bc32c1 Mon Sep 17 00:00:00 2001 From: =?utf8?q?Tim=20D=C3=BCsterhus?= Date: Fri, 5 Feb 2021 15:55:06 +0100 Subject: [PATCH] Update MysqlSearchEngine::getFulltextMinimumWordLength() for InnoDB At the same time copy over the deprecation comment from AbstractSearchEngine. see 7d059540531e82c12b0aec2ad50e38a6788657cc Resolves #3948 --- .../lib/system/search/mysql/MysqlSearchEngine.class.php | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/wcfsetup/install/files/lib/system/search/mysql/MysqlSearchEngine.class.php b/wcfsetup/install/files/lib/system/search/mysql/MysqlSearchEngine.class.php index 2d66c00ec0..0c292b5b18 100644 --- a/wcfsetup/install/files/lib/system/search/mysql/MysqlSearchEngine.class.php +++ b/wcfsetup/install/files/lib/system/search/mysql/MysqlSearchEngine.class.php @@ -22,8 +22,7 @@ use wcf\util\StringUtil; class MysqlSearchEngine extends AbstractSearchEngine { /** - * MySQL's minimum word length for fulltext indices - * @var int + * @deprecated 5.4 - This property is used for the deprecated getFulltextMinimumWordLength(). */ protected $ftMinWordLen; @@ -457,12 +456,12 @@ class MysqlSearchEngine extends AbstractSearchEngine } /** - * @inheritDoc + * @deprecated 5.4 - This method was required for use in parseSearchQuery(). */ protected function getFulltextMinimumWordLength() { if ($this->ftMinWordLen === null) { - $sql = "SHOW VARIABLES LIKE 'ft_min_word_len'"; + $sql = "SHOW VARIABLES LIKE 'innodb_ft_min_token_size'"; try { $statement = WCF::getDB()->prepareStatement($sql); @@ -470,7 +469,7 @@ class MysqlSearchEngine extends AbstractSearchEngine $row = $statement->fetchArray(); } catch (DatabaseException $e) { // fallback if user is disallowed to issue 'SHOW VARIABLES' - $row = ['Value' => 4]; + $row = ['Value' => 3]; } $this->ftMinWordLen = $row['Value']; -- 2.20.1