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

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

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

> 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

dawei

【声明】:唐山站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。