wordpress边栏最近热门浏览排行
作者: 郑晓 分类: wordpress 发布于: 2017-03-22 13:29 浏览:23,812 评论(3)
博客右侧边栏的最近热门文章列表,展示的是最近30条文章中浏览最多的前10条数据。
这里浏览量基于插件WP-PostViews实现。
主题functions.php中增加函数get_hot()
:
function get_hot() {
global $wpdb;
if ($posts = wp_cache_get('posts', '30-hot-archives')) return $posts;
$query = "SELECT ID,post_title,post_name,CONVERT(meta_value, SIGNED) as views FROM (select ID,post_title,post_name from $wpdb->posts WHERE post_type='post' AND post_status = 'publish' AND comment_status = 'open' order by ID desc limit 30) as p left join $wpdb->postmeta m on p.ID=m.post_id and m.meta_key='views' order by views desc limit 10";
$posts = $wpdb->get_results($query);
wp_cache_set('posts', $posts, '30-hot-archives');;
return $posts;
}
sql中先查询最近30条文章,然后和postmeta表中meta_key为views的记录进行联接查询,最后再按meta_value的值进行desc排序,也就是浏览量排序。 其中注意meta_value由于类型是字符串,直接排序会有问题,所以这里需要先使用convert转为signed类型。
主题边栏sidebar.php中需要展示列表的地方使用get_host()调用获得数据,然后可以进行遍历输出。
本文采用知识共享署名-非商业性使用 3.0 中国大陆许可协议进行许可,转载时请注明出处及相应链接。
本文永久链接: https://www.zh30.com/wordpress-sidebar-hot-posts.html
wordpress边栏最近热门浏览排行:目前有3 条留言
我看看………..
感谢分享,这个不错
从百度进来的,博客不错哦!