【问题标题】:unable to find desired result in search filter query无法在搜索过滤器查询中找到想要的结果
【发布时间】:2019-08-13 06:54:46
【问题描述】:

我从过去 2 天开始尝试在查询中获得所需的结果,但无法做到这一点。基本上,我正在查询餐厅网站“基于标签”的搜索过滤器,以搜索最喜欢的菜肴。

有一个单独的标签表,其中有很多标签保存在 meal_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%'
   )

上面贴图是当前结果,问题是查询返回记录,其中tag_meal是"tuna",tag_restaurant是"karaoke",但匹配时返回空但另一个没有。

我希望即使一个条件匹配,查询也能返回结果假设我为 "meal" 写了 2 个标签,而为 "restaurant" 写了 2 个标签,反之亦然,同时我希望查询使用 AND,因为我想减少结果的数量。

请在这方面帮助我。谢谢。

【问题讨论】:

  • stackoverflow.com/help/mcve 会让事情变得更容易。
  • 我已经提供了所有的东西。
  • 那张带有小文字的图片,是样本表数据还是预期结果?
  • @jarlh 这是当前结果
  • @jarlh 现在检查,它更具可读性

标签: mysql sql database relational-database


【解决方案1】:

正如我所评论的,获取与一条或另一条记录匹配的所有行的方法是对它们进行 OR。

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%'
   )

这不是那么有效。您可以构建一个正则表达式进行优化。

【讨论】:

    猜你喜欢
    • 2016-01-11
    • 2019-04-17
    • 2015-11-24
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-12-12
    • 2012-10-20
    • 1970-01-01
    相关资源
    最近更新 更多