gpt4 book ai didi

MySQL 评分/投票系统(根据票数按最佳评分准确排序)

转载 作者:行者123 更新时间:2023-11-29 02:08:29 27 4
gpt4 key购买 nike

假设我有一个像这样的 MySQL 表:

软件表:

id int
name text
votes int
rating int

其中投票是某人为该项目投票的次数,评分是这些投票的平均值。

示例数据:

id: 0
name: FooBar!
votes: 5
rating: 3

现在另一个用户出现并给它打了 1 分。我将如何计算新的评级?每次有人投票时,最好制作另一个表格并输入一个新行

id int
software_id int
score int
user_id int

然后每次都重新计算平均评分?我认为这会对服务器造成影响。

第二个问题:

我希望能够按评分最高的顺序对软件进行排序,但我不希望平均评分为 5 星但仅获得 1 票的程序排名高于平均评分为 4 且获得 893 票的程序.我将如何做到这一点?

最佳答案

问题 1a:如何计算新的平均评分:

vote count : 5
average rating: 3

评分为 one 的新投票

             5*3+1
new rating= ----- = 16/6 = 8/3 = 2.666..
6

您必须考虑新投票的“权重”(所有选票的 1/6)和旧平均值(6 次中出现 5 次)。旧平均值 3 计算 5 次,新评级一次=> 5*3 +1= 16。然后除以收到的 6 票总数。

问题 1b:您应该存储选票吗?

真的取决于你是否希望成为游戏玩家

我建议你这样做。

关于MySQL 评分/投票系统(根据票数按最佳评分准确排序),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1670005/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com