题解 | #更新用户积分信息?#

更新用户积分信息?

https://www.nowcoder.com/practice/ef1f2fda4338460b948810f3f7e7a68e

这道题目要求我们更新用户的积分信息,我们要做的事情如下:

1. 确定总体问题

我们需要根据订单数据更新用户的积分。用户在订单金额大于100时,可以获得与订单金额相同的积分。我们需要从订单信息和用户会员等级信息中提取数据,计算每个用户的总积分,并按积分降序排序。

2. 分析关键问题

  • 筛选有效订单:从order_tb中筛选出订单金额大于100的订单。
  • 连接表:将筛选出的订单与uservip_tb表连接,以便获取每个用户的积分信息。
  • 计算总积分:将用户的原始积分与有效订单的积分相加,计算每个用户的总积分。
  • 过滤无效用户:只输出有有效订单的用户。
  • 排序输出:按总积分降序排序。

3. 解决每个关键问题的代码及讲解

步骤1:筛选有效订单

我们使用子查询从order_tb中筛选出订单金额大于100的订单:

LEFT JOIN (
    SELECT
        user_id,
        order_price
    FROM
        order_tb
    WHERE
        order_price > 100
) o ON u.user_id = o.user_id
  • WHERE order_price > 100:筛选出订单金额大于100的订单。
步骤2:连接表

将筛选出的订单与uservip_tb表连接:

FROM
    uservip_tb u
    LEFT JOIN (
        -- 子查询
    ) o ON u.user_id = o.user_id
  • LEFT JOIN:确保即使某个用户没有符合条件的订单,用户信息也能显示。
步骤3:计算总积分

将用户的原始积分与有效订单的积分相加,计算每个用户的总积分:

u.point + SUM(o.order_price) AS point
  • SUM(o.order_price):计算每个用户的有效订单总金额。
  • u.point + ...:将用户的原始积分与有效订单的积分相加。
步骤4:过滤无效用户

只输出有有效订单的用户:

HAVING
    SUM(o.order_price) > 0
  • HAVING SUM(o.order_price) > 0:过滤掉没有有效订单的用户。
步骤5:排序输出

按总积分降序排序输出结果:

ORDER BY
    point DESC

完整代码

SELECT
    u.user_id,
    u.point + SUM(o.order_price) AS point
FROM
    uservip_tb u
    LEFT JOIN (
        SELECT
            user_id,
            order_price
        FROM
            order_tb
        WHERE
            order_price > 100
    ) o ON u.user_id = o.user_id
GROUP BY
    u.user_id
HAVING
    SUM(o.order_price) > 0
ORDER BY
    point DESC;
全部评论
请教各位大佬,left join有必要嘛,后面又having筛选。前面直接join,后面不having可以吗?
点赞 回复 分享
发布于 2025-07-03 18:50 江西
题目中已经说了,未获得积分的用户不用输出,那么为什么还要用leftjoin呢?left join不是把所有用户的信息都输出了吗?
点赞 回复 分享
发布于 2025-05-08 19:34 黑龙江

相关推荐

03-24 13:24
已编辑
江西农业大学 后端工程师
最近或许大家都听说xxxx厂裁员,无论前端,后端,大数据,测试,运维,人人可危, “前端死了,后端也死了,JAVA崩盘了,你们这群搞大模型的真是码奸”这次AI真的会让我们无路可走吗????????太阳底下已经没有新鲜事了旧的生产力的消失,必然有新的生产力诞生马车夫消失 → 汽车司机、修车工、石油工业诞生,从业人数是马车夫的百倍手工纺织女工消失 → 纺织机械工程师、面料设计师诞生,纺织品产量提升百倍2007年苹果开放 App Store,"移动端开发者"这个职业压根不存在。八年后,全球应用经济规模突破 1000亿美元,凭空诞生了数百万开发者岗位。每一次"这次真的完了...
二十岁的编程男神王大...:那这个时代是什么时代呢? 是全员agent的时代,是前端+AI,后端+AI的时代,AI已经融入了项目生命周期的的每一个角落,那我最近在做的东西举例,检查BUG时,我们会用codex,CC等工具的skill去check,效果好还能直接fix,测试的时候,apifox等工具已经有了AI落地的改造,CI/CD阶段,我们会根据hook去跑AI check脚本,就连不少中间件,也迎来了AI落地的改造,(AI网关,AI在MQ中的运用),都可以去了解下 另外记着,这些东西不是意义,工作只是谋生的一个手段,ai是让开发提效了,但是呢,原先一周的工作流程压缩到了两天内,同时低级的都裁员了,只有高级的去维护,你看似写的大义凛然,或许那天你也会成为你文章里面拒绝往前走的人,你才大二,面对技术有热情是对的
AI求职实录
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务