SQL - 按来自多个表的信息对表进行排序

如何解决SQL - 按来自多个表的信息对表进行排序

问题的标题可能不是很清楚 - 我不确定如何命名这个问题,但我希望我的解释能让我的问题更清楚。

我有 3 张桌子:

[1] 得分

id rating_type
1 UPVOTE
2 UPVOTE
3 DOWNVOTE
4 UPVOTE
5 DOWNVOTE
6 DOWNVOTE

[2] post_score

post_id score_id
1 1
1 2
1 3
2 4
2 5
2 6

和 [3] 发布

id title
1 title1
2 title2

我的目标是按分数排序 [3] 发布表。

假设UPVOTE代表值为1,DOWNVOTE值为-1;在这个例子中,id = 1 的帖子有 3 个与之相关的分数,它们的值分别是 UPVOTE、UPVOTE、DOWNVOTE,构成了这个帖子的“数字分数”:2;

同样,id = 2 的帖子也有 3 个分数,这些值分别是:UPVOTE、DOWNVOTE、DOWNVOTE,构成“数字分数”:-1;

我将如何按此分数订购 post table?在这个例子中,如果我按分数 asc 排序,我希望得到以下结果:

id title
2 title2
1 title1

我的尝试并没有走多远,我目前被这个查询困在这里,它并没有真正做任何有用的事情:

WITH fullScoreInformation AS (
    SELECT * FROM score s
    JOIN post_score ps ON s.id = ps.score_id),upvotes AS (SELECT * FROM fullScoreInformation WHERE rating_type = 'UPVOTE'),downvotes AS (SELECT * FROM fullScoreInformation WHERE rating_type = 'DOWNVOTE')
SELECT p.id,rating_type,title FROM post p JOIN fullScoreInformation fsi on p.id = fsi.post_id

我正在使用 PostgreSQL。查询将在我的 Spring Boot 应用程序中使用(我通常使用原生查询)。

也许这个数据结构很糟糕,我应该以不同的方式构建我的实体?

解决方法

我的目标是按分数对帖子表进行排序。假设 UPVOTE 代表 1 的值,DOWNVOTE 代表 -1 的值

一个选项使用子查询来计算每个帖子的赞成票和反对票:

select p.*,s.*
from post p
cross join lateral (
    select 
        count(*) filter(where s.rating_type = 'UPVOTE'  ) as cnt_up,count(*) filter(where s.rating_type = 'DOWNVOTE') as cnt_down
    from post_score ps
    inner join score s on s.id = ps.score_id
    where ps.post_id = p.id
) s
order by s.cnt_up - s.cnt_down desc

也许这个数据结构很糟糕,我应该以不同的方式构建我的实体?

就目前而言,我认为不需要两个不同的表 post_scorescore。对于您显示的数据,这是一种 1-1 关系,因此只有一张表就足够了,用于存储帖子 ID 和评分类型。

,

您最好使用 LEFT 联接,否则您不会收到尚未投票的帖子。然后聚合以获得分数的拟合总和。然后将这些总和相加,对没有投票的帖子应用 coalesce() 得到 0,并按结果排序。

SELECT p.id,p.title
       FROM post p
            LEFT JOIN post_score ps
                      ON ps.post_id = p.id
            LEFT JOIN score s
                      ON s.id = ps.score_id
       GROUP BY p.id,p.title
       ORDER BY coalesce(sum(1) FILTER (WHERE rating_type = 'UPVOTE')
                         +
                         sum(-1) FILTER (WHERE rating_type = 'DOWNVOTE'),0);

我同意 GMB 关于多余桌子的评论。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams['font.sans-serif'] = ['SimHei'] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -> systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping("/hires") public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate<String
使用vite构建项目报错 C:\Users\ychen\work>npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-
参考1 参考2 解决方案 # 点击安装源 协议选择 http:// 路径填写 mirrors.aliyun.com/centos/8.3.2011/BaseOS/x86_64/os URL类型 软件库URL 其他路径 # 版本 7 mirrors.aliyun.com/centos/7/os/x86
报错1 [root@slave1 data_mocker]# kafka-console-consumer.sh --bootstrap-server slave1:9092 --topic topic_db [2023-12-19 18:31:12,770] WARN [Consumer clie
错误1 # 重写数据 hive (edu)> insert overwrite table dwd_trade_cart_add_inc > select data.id, > data.user_id, > data.course_id, > date_format(
错误1 hive (edu)> insert into huanhuan values(1,'haoge'); Query ID = root_20240110071417_fe1517ad-3607-41f4-bdcf-d00b98ac443e Total jobs = 1
报错1:执行到如下就不执行了,没有显示Successfully registered new MBean. [root@slave1 bin]# /usr/local/software/flume-1.9.0/bin/flume-ng agent -n a1 -c /usr/local/softwa
虚拟及没有启动任何服务器查看jps会显示jps,如果没有显示任何东西 [root@slave2 ~]# jps 9647 Jps 解决方案 # 进入/tmp查看 [root@slave1 dfs]# cd /tmp [root@slave1 tmp]# ll 总用量 48 drwxr-xr-x. 2
报错1 hive> show databases; OK Failed with exception java.io.IOException:java.lang.RuntimeException: Error in configuring object Time taken: 0.474 se
报错1 [root@localhost ~]# vim -bash: vim: 未找到命令 安装vim yum -y install vim* # 查看是否安装成功 [root@hadoop01 hadoop]# rpm -qa |grep vim vim-X11-7.4.629-8.el7_9.x
修改hadoop配置 vi /usr/local/software/hadoop-2.9.2/etc/hadoop/yarn-site.xml # 添加如下 <configuration> <property> <name>yarn.nodemanager.res