duanmei1694 2015-03-03 19:46
浏览 373
已采纳

MySQL LEFT JOIN导致“重复”行

I have tables "customers" and "plans" and I want to list all customers regardless they have a plan or not. I'm using query to do it

SELECT customer.name, plan.goal
FROM customer
LEFT JOIN plan ON plan.customerid=customer.customerid
ORDER BY customer.name

I also want to see the goal (plan.goal) with the customer name. This works as long as customer does not have a plan or has a single plan. If customer has two or more plans then I get as many rows of customer name as there are plans.

What I want is customer.name and plan.goal from the latest plan. We can assume the higher value in plan.planid is the latest plan.

I guess I should use sub queries and INNER JOINS some how but I just don't get it right now...

  • 写回答

3条回答 默认 最新

  • dongpu3898 2015-03-03 19:54
    关注

    I would think something like this would work:

    SELECT customer.name, plan.goal
    FROM customer c
    inner join plan p on c.customerId = p.customerId
    inner JOIN (
        -- grabs the most recent plan per customer
        select max(planId) as planId, customerId
        from plan
        group by customerId
    ) maxPlan on p.planId = maxPlan.planId
    UNION
    -- handles customers w/o a plan
    select customer.name, null
    from customer c
    left join plan p on c.customerId = p.customerId
    where p.customerId is null
    ORDER BY customer.name
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)