我有以下代码,并且我想根据他的总余额仅获得用户的联盟排名。我怎样才能做到这一点?如何获得使用MySQL的MySQL查询排名
// Set League Rank by User
global $post;
$post_author = $post->post_author;
$post_status = 'publish';
$meta_key = 'balance';
$rank = $wpdb->get_var($wpdb->prepare(
"
SELECT *, @rownum := @rownum + 1 from
(
SELECT
SUM(meta_value) as balance,
FROM {$wpdb->postmeta} pm
INNER JOIN {$wpdb->posts} p ON pm.post_id = p.ID
JOIN (SELECT @curRow := 0) r;
WHERE pm.meta_key = %s AND p.post_author = %s AND p.post_status = %s
order by balance desc)x, (SELECT @rownum := 0) r
",
$meta_key, $post_author, $post_status
));
可以帮助我吗?
谢谢。
你可以发布有问题的两个表的表定义吗? – Orangepill 2013-05-14 15:08:53
你在哪里设置$ meta_key – Anigel 2013-05-14 15:14:05
这段代码很适合检索每个用户的余额。我需要的是获得排名,这是表中不存在的列。 – qebas 2013-05-14 15:15:02