加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

php – 按贝叶斯评级订购数据库结果

发布时间:2020-12-11 23:48:14 所属栏目:MySql教程 来源:网络整理
导读:我不确定这是否可行,但在做“丑陋”的方式之前我需要确认:) 因此,“结果”是数据库中的帖子,存储方式如下: posts表,其中包含所有重要的内容,如ID,标题,内容 后元表,其中包含额外的帖子数据,如评级(this_rating)和投票数(this_num_votes).该数据成对存储,该

我不确定这是否可行,但在做“丑陋”的方式之前我需要确认:)

因此,“结果”是数据库中的帖子,存储方式如下:

> posts表,其中包含所有重要的内容,如ID,标题,内容
>后元表,其中包含额外的帖子数据,如评级(this_rating)和投票数(this_num_votes).该数据成对存储,该表有3列:帖子ID /键/值.它基本上是WordPress表结构.

我想要的是取出评分最高的帖子,根据这个公式排序:

br = ( (avg_num_votes * avg_rating) + (this_num_votes * this_rating) )
/ (avg_num_votes + this_num_votes)

我偷了here表格.

avg_num_votes和avg_rating是已知变量(它们在每次投票时都会更新),因此不需要计算它们.

这可以用mysql查询完成吗?或者我是否需要获取所有帖子并使用PHP进行排序?

最佳答案 数据堆栈交换链接:

http://data.stackexchange.com/stackoverflow/s/2137/order-database-results-by-bayesian-rating

SELECT id,title,( AVG(this_num_votes) * AVG(this_rating) + this_num_votes * this_rating )
     / ( AVG(this_num_votes) + this_num_votes ) as br
FROM posts
LEFT JOIN (
SELECT DISTINCT post_id,(SELECT meta_value FROM postmeta WHERE postmeta.post_id = pm.post_id AND meta_key ='this_num_votes') as this_num_votes,(SELECT meta_value FROM postmeta WHERE postmeta.post_id = pm.post_id AND meta_key ='this_rating') as this_rating
FROM postmeta pm ) as newmeta ON posts.ID = newmeta.post_id
GROUP BY id,this_num_votes,this_rating
ORDER BY br DESC

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读