gpt4 book ai didi

php - MySQL SELECT 概率喜恶系统

转载 作者:塔克拉玛干 更新时间:2023-11-03 06:02:11 25 4
gpt4 key购买 nike

我正在为我的博客网站创建一个 YouTube 评论风格(喜欢-不喜欢)PHP 应用程序。

我想让评论随机排列;但是,我希望根据喜欢与不喜欢的比例增加机会。例如:

5 个赞和 1 个不喜欢的评论比 4 个赞和 2 个不喜欢的评论更有可能被选中,因为 5/1 高于 4/2。因此,好恶率与在评论区被展示的几率成正比。

我正在使用 PHP 和 MySQL。我需要为此创建某种算法的帮助。我知道这非常具有挑战性,但如果您能为此想到某种 MySQL 查询,那就太好了。 :D

最佳答案

假设您有一个评论表,其中包含 NumLikesNumDislikes 等列。

您可以采用的一种简单方法是按比率(或按喜欢降序的概率)对行进行排序,并偏向于选择较低的行而不是较高的行。

下面随机选择一行,然后随机选择比该行比例更好的行。这会使选择过程偏向更好的行:

select *
from comments c cross join
(select c.*
from comments c
order by rand() desc
limit 1
) threshhold
where c.likes / (c.likes + c.dislikes) >= threshold.likes / (threshold.likes + threshold.dislikes)
order by rand()
limit 1

还有更复杂的技术。因为 MySQL 不支持窗口/分析函数,所以它们最容易用临时表和多个查询来实现。但是,这种方法只需要一个查询,不需要临时表。

关于php - MySQL SELECT 概率喜恶系统,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16848924/

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