查询Jetpack Wordpress统计列表

时间:2017-11-03 12:47:00

标签: wordpress jetpack

我希望在小部件中显示本周观看次数最多的帖子。

<?php

function filter_where($where = '') {
    //posts in the last 30 days
    $where .= " AND post_date > '" . date('Y-m-d', strtotime('-30 days')) . "'";
    return $where;
}
add_filter('posts_where', 'filter_where');

query_posts('post_type=post&posts_per_page=4&orderby=rand&order=DESC');

while (have_posts()): the_post(); ?>

<li style="
    margin-bottom: 5px;
    background: transparent url(http://i.imgur.com/6ngfnNo.png) repeat scroll center top;
    padding: 15px;
    list-style-type: none;
    width: 500px;
    margin: 10px 0px 0px 10px;
"><a href="<?php the_permalink(); ?>" title="<?php printf(esc_attr('Permalink to %s'), the_title_attribute('echo=0')); ?>" rel="bookmark"><span class="tptn_title" style="
    color: #fff;
    text-transform: uppercase;
    font-family: 'Montserrat-Bold', sans-serif;
"><?php the_title(); ?></span></a></li>

<?php
endwhile;
wp_reset_query();
?>

我正在使用这个,因为Jetpack不允许我查询查看次数最多的帖子。

1 个答案:

答案 0 :(得分:0)

您可以尝试以下方法:

<?php 
// creating the post views DB table
add_action('wp_head', 'create_post_views_table');
function create_post_views_table() {
    global $wpdb;
    // our table name
    $table_name = $wpdb->prefix . "post_views";
    // SQL for creating the table
    $sql = "CREATE TABLE IF NOT EXISTS $table_name (
            meta_id int(11) NOT NULL AUTO_INCREMENT,
            post_id int(11) NOT NULL,
            date_viewed datetime NOT NULL,
            PRIMARY KEY (meta_id)
        ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;";
    // we're using functions from the WP admin
    require_once(ABSPATH . 'wp-admin/includes/upgrade.php');
    // executing the SQL
    dbDelta($sql);
}
?>

<?php 
// Add this function when user sees the post / most likely in single.php or loop-single etc. 

// recording each post view
function update_post_views($postID) {
    global $wpdb;
    // our table name
    $table_name = $wpdb->prefix . "post_views";
    // the current time 
    $date = date('Y-m-d H:i:s');
    // the SQL for inserting the view
    $sql = "INSERT INTO $table_name (post_id,date_viewed) VALUES ($postID, '$date')";
    // executing the SQL
    $wpdb->query($sql);
}
?>

<?php 
// get the most popular posts for the last X days
function get_most_popular_posts($count = 30, $interval = '') {
    global $wpdb;
    $where = '';
    // adding WHERE clause to specify the date interval 
    if ($interval) {
        $where = "
        WHERE date_viewed > ( NOW() - INTERVAL $interval DAY)
        ";
    }
    // building SQL
    $sql = "SELECT post_id, COUNT(post_id) as count
            FROM {$wpdb->prefix}post_views
            {$where}
            GROUP BY post_id
            ORDER BY count DESC
            LIMIT $count
            ";
    // fetching the posts
    $results = $wpdb->get_results($sql);
    return $results;
}
?>