Skip to content
Snippets Groups Projects
Commit 124daec8 authored by Jan-Hendrik Willms's avatar Jan-Hendrik Willms
Browse files

Revert "optimize performance of query from GlobalSearchCourses::getSQL(), re #1561"

This reverts commit 5761b25d.

re #1561
parent 5761b25d
No related branches found
No related tags found
No related merge requests found
...@@ -47,16 +47,7 @@ class GlobalSearchCourses extends GlobalSearchModule implements GlobalSearchFull ...@@ -47,16 +47,7 @@ class GlobalSearchCourses extends GlobalSearchModule implements GlobalSearchFull
$search = str_replace(' ', '% ', $search); $search = str_replace(' ', '% ', $search);
$query = DBManager::get()->quote("%{$search}%"); $query = DBManager::get()->quote("%{$search}%");
$language_name = 'courses.`Name`'; $language = DBManager::get()->quote($_SESSION['_language']);
$language_join = '';
if ($_SESSION['_language'] !== Config::get()->DEFAULT_LANGUAGE) {
$language_name = 'IFNULL(`i18n`.`value`, courses.`Name`)';
$language_join = "LEFT JOIN `i18n`
ON `i18n`.`object_id` = courses.`Seminar_id`
AND `i18n`.`table` = 'seminare'
AND `i18n`.`field` = 'name'
AND `lang` = " . DBManager::get()->quote($_SESSION['_language']);
}
// visibility // visibility
if (!$GLOBALS['perm']->have_perm('admin')) { if (!$GLOBALS['perm']->have_perm('admin')) {
...@@ -96,18 +87,25 @@ class GlobalSearchCourses extends GlobalSearchModule implements GlobalSearchFull ...@@ -96,18 +87,25 @@ class GlobalSearchCourses extends GlobalSearchModule implements GlobalSearchFull
} }
$sql = "SELECT SQL_CALC_FOUND_ROWS courses.`Seminar_id`, courses.`start_time`, $sql = "SELECT SQL_CALC_FOUND_ROWS courses.`Seminar_id`, courses.`start_time`,
{$language_name} AS `Name`, IFNULL(`i18n`.`value`, courses.`Name`) AS `Name`,
courses.`VeranstaltungsNummer`, courses.`status` courses.`VeranstaltungsNummer`, courses.`status`
FROM `seminare` AS courses FROM `seminare` AS courses
{$language_join} LEFT JOIN `i18n`
ON `i18n`.`object_id` = courses.`Seminar_id`
AND `i18n`.`table` = 'seminare'
AND `i18n`.`field` = 'name'
AND `lang` = {$language}
JOIN `sem_types` ON (courses.`status` = `sem_types`.`id`)
JOIN `seminar_user` u ON (u.`Seminar_id` = courses.`Seminar_id` AND u.`status` = 'dozent') JOIN `seminar_user` u ON (u.`Seminar_id` = courses.`Seminar_id` AND u.`status` = 'dozent')
JOIN `auth_user_md5` a ON (a.`user_id` = u.`user_id`) JOIN `auth_user_md5` a ON (a.`user_id` = u.`user_id`)
{$semester_join} {$semester_join}
WHERE {$visibility} WHERE {$visibility}
( (
{$language_name} LIKE {$query} IFNULL(`i18n`.`value`, courses.`Name`) LIKE {$query}
OR courses.`VeranstaltungsNummer` LIKE {$query} OR courses.`VeranstaltungsNummer` LIKE {$query}
OR CONCAT(a.`Nachname`, ', ', a.`Vorname`, ' ', a.`Nachname`) LIKE {$query} OR CONCAT_WS(' ', `sem_types`.`name`, IFNULL(`i18n`.`value`, courses.`Name`), `sem_types`.`name`) LIKE {$query}
OR CONCAT_WS(', ', a.`Nachname`, a.`Vorname`) LIKE {$query}
OR CONCAT_WS(' ', a.`Nachname`, a.`Vorname`, a.`Nachname`) LIKE {$query}
) )
{$seminaruser} {$seminaruser}
{$institute_condition} {$institute_condition}
...@@ -120,7 +118,7 @@ class GlobalSearchCourses extends GlobalSearchModule implements GlobalSearchFull ...@@ -120,7 +118,7 @@ class GlobalSearchCourses extends GlobalSearchModule implements GlobalSearchFull
$sql .= ", courses.`VeranstaltungsNummer`"; $sql .= ", courses.`VeranstaltungsNummer`";
} }
$sql .= ", {$language_name}"; $sql .= ", IFNULL(`i18n`.`value`, courses.`Name`)";
$sql .= " LIMIT " . $limit; $sql .= " LIMIT " . $limit;
return $sql; return $sql;
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment