невозможно найти желаемый результат в поисковом фильтре - PullRequest
0 голосов
/ 22 марта 2019

Я пытаюсь за последние 2 дня получить желаемый результат в запросе, но не могу этого сделать. В основном я делаю запрос для поискового фильтра по любимым блюдам на основе тегов.

Есть отдельная таблица для тегов, в которой столько тегов сохранено в отношении food_id, restaurant_id. Отношение ко многим из ресторанов-> теги и питание-> теги ..

Чем больше тегов введено пользователями, тем меньше будет результатов.

Пожалуйста, посмотрите на запрос

SELECT
   ep_tag.tag_en as tag_meal,
   ep_tag2.tag_en as tag_restaurant,
   `ep_meal`.id as id_meal,
   `ep_meal`.name as name_plat,
   `ep_meal`.`id_budget`,
   `ep_meal_favorite`.date,
   `ep_restaurant`.id as `id_restaurant`,
   `ep_restaurant`.* 
from
   `ep_meal` 
   inner join
      `ep_meal_favorite` 
      on `ep_meal_favorite`.`id_meal` = `ep_meal`.id 
   inner join
      `ep_restaurant` 
      on `ep_meal_favorite`.`id_restaurant` = `ep_restaurant`.`id` 
   inner JOIN
      ep_tag 
      ON ep_meal_favorite.id_meal = ep_tag.id_meal 
   inner JOIN
      ep_tag as ep_tag2 
      ON ep_meal_favorite.id_restaurant = ep_tag2.id_restaurant 
where
   ep_meal_favorite.id_epicurean = 82 
   and `ep_restaurant`.id = 14 
   and `ep_meal`.id = 92 
   AND 
   (
      ep_tag.tag_en LIKE '%tuna%' 
      OR ep_tag2.tag_en LIKE'%tuna%'
   )
   AND 
   (
      ep_tag.tag_en LIKE '%karaoke%' 
      OR ep_tag2.tag_en LIKE'%karaoke%'
   )

enter image description here

выше размещенного изображения - это текущий результат, проблема в том, что записи запросов возвращаются, где tag_meal равно "тунец" , а tag_restaurant равно "караоке" , но оно возвращается пустым, если сопоставляется одно, а другое один не делает.

Я хочу, чтобы запрос возвращал результаты, когда хотя бы одно условие соответствовало, предположим, что я пишу 2 тега для "еды" и без тега для "ресторана" и наоборот, в В то же время я хочу, чтобы запрос использовал AND, потому что я хочу уменьшить количество результатов.

Пожалуйста, помогите мне в этом отношении. Спасибо.

1 Ответ

0 голосов
/ 22 марта 2019

Как я прокомментировал, способ получить все строки, которые соответствуют той или иной записи, - это ИЛИ их.

SELECT
   ep_tag.tag_en as tag_meal,
   ep_tag2.tag_en as tag_restaurant,
   `ep_meal`.id as id_meal,
   `ep_meal`.name as name_plat,
   `ep_meal`.`id_budget`,
   `ep_meal_favorite`.date,
   `ep_restaurant`.id as `id_restaurant`,
   `ep_restaurant`.* 
from
   `ep_meal` 
   inner join
      `ep_meal_favorite` 
      on `ep_meal_favorite`.`id_meal` = `ep_meal`.id 
   inner join
      `ep_restaurant` 
      on `ep_meal_favorite`.`id_restaurant` = `ep_restaurant`.`id` 
   inner JOIN
      ep_tag 
      ON ep_meal_favorite.id_meal = ep_tag.id_meal 
   inner JOIN
      ep_tag as ep_tag2 
      ON ep_meal_favorite.id_restaurant = ep_tag2.id_restaurant 
where
   ep_meal_favorite.id_epicurean = 82 
   and `ep_restaurant`.id = 14 
   and `ep_meal`.id = 92 
   AND 
   (
      ep_tag.tag_en LIKE '%tuna%' 
      OR ep_tag2.tag_en LIKE'%tuna%'
      OR ep_tag.tag_en LIKE '%karaoke%' 
      OR ep_tag2.tag_en LIKE'%karaoke%'
   )

Это не так эффективно, хотя.Вы можете построить регулярное выражение для оптимизации.

...