douchongbc72264 2014-01-14 12:35
浏览 79
已采纳

使用join的构建一个mysql查询,以便在symfony中使用

DB struct:

DB Struct

DB description

One comapny can have review (0,1 or more) review always have reviews_item all reviews_item have one category

Problem

I need SQL query that makes list of 'company's with AVG value of reviews_items.value, i need it to set order by this value. Even if for some 'company' i dont have any 'reviews' and 'reviews_items' comapny should be in list with AVG == 0. it should select companies only with active == 1 and (if exists) review active==1

My slq query, dont work propertly:

SELECT 
    c.name,c.logo,c.url,
    AVG(ri.value) as avarage
FROM company c
LEFT JOIN reviews r ON r.company_id = c.id
LEFT JOIN reviews_items ri ON ri.review_id = r.id
LEFT JOIN category cat ON ri.category_id = cat.id
WHERE c.active = 1
GROUP BY c.id

I hope that my problem is clear :)

PS. Sorry if my language (english) is not so good :D

  • 写回答

3条回答 默认 最新

  • donglvhe7591 2014-01-14 14:13
    关注

    There was missing sth in WERE clausule (OR r.active IS NULL):

    SELECT 
      c.name,c.logo,c.url,
      AVG(NULLIF(ri.value,0)) as avarage
    FROM company c
     LEFT JOIN reviews r ON r.company_id = c.id
     LEFT JOIN reviews_items ri ON ri.review_id = r.id
     LEFT JOIN category cat ON ri.category_id = cat.id
    WHERE c.active = 1 AND (r.active = 1 OR r.active IS NULL)
     GROUP BY c.id
    ORDER BY avarage  DESC
    

    Thanks for trying!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
  • ¥20 软件测试决策法疑问求解答
  • ¥15 win11 23H2删除推荐的项目,支持注册表等
  • ¥15 matlab 用yalmip搭建模型,cplex求解,线性化处理的方法
  • ¥15 qt6.6.3 基于百度云的语音识别 不会改
  • ¥15 关于#目标检测#的问题:大概就是类似后台自动检测某下架商品的库存,在他监测到该商品上架并且可以购买的瞬间点击立即购买下单
  • ¥15 神经网络怎么把隐含层变量融合到损失函数中?
  • ¥15 lingo18勾选global solver求解使用的算法
  • ¥15 全部备份安卓app数据包括密码,可以复制到另一手机上运行
  • ¥20 测距传感器数据手册i2c