某段时间内的读者墙

前言:读者墙,我想大家都很熟悉了,目前网上流传的代码版本主要有2个,一个是水--岩之源(博客已关闭)原创的按自然月统计的,一个是willin修改的按最近30天内的(我博客目前使用的)

本文的产生:木木木木木同学昨天迎来了他的博客二周年,正在搞评论有奖活动《喜迎小站二周年,评论有奖活动》,荒淫大家踊跃参与,其内容如下

活动时间:2010.8.1 16:16~2010.08.31 24:00

活动奖项:

1.沙银:3名,活动期间沙发数最多的前3人,将分别获得¥30、¥20、¥10;

2.水银:3名,活动期间评论数最多的前3人,将分别获得¥30、¥20、¥10;

活动说明:活动结束后,会通知获奖的银,通过支付宝直接支付,活动的一切解释权归林木木所有! ^ ^

很多朋友就说了,这跟本文有啥关系呢?因为本活动木木需要即时统计按评论数量排列活动期间的读者头像,于是就需要对现有的读者墙代码进行修改鸟,木木自己没搞定。

木木来问我,我也不熟悉 SQL,很多代码都是测试出来的,于是立马测试,没想到乱撞还是搞定鸟。

问题的解决:代码如下:

<ul class="ffox_most_active">
     <?php
     $limit_num = '16';
     $noneurl = get_bloginfo ('url');
     $my_email = "'" . get_bloginfo ('admin_email') . "'";
     $counts = $wpdb->get_results("
         SELECT COUNT(comment_author) AS cnt, comment_author, comment_author_url, comment_author_email
         FROM (SELECT * FROM $wpdb->comments LEFT OUTER JOIN $wpdb->posts
         ON ($wpdb->posts.ID=$wpdb->comments.comment_post_ID)
         WHERE comment_date > date_sub( '2010-09-01 00:00:00', INTERVAL 43664 MINUTE )
         AND user_id='0'
         AND comment_author_email != $my_email
         AND post_password=''
         AND comment_approved='1'
         AND comment_type='') AS tempcmt    GROUP BY comment_author_email
         ORDER BY cnt DESC LIMIT $limit_num
     ");
     foreach ($counts as $count) {
       $c_url = $count->comment_author_url;
       if ($c_url == '') $c_url = $noneurl;
       $mostactive .= '<li class="mostactive">' . '<a href="'. $c_url . '" title="' . $count->comment_author . ' ('. $count->cnt . 'comments)">'.get_avatar($count->comment_author_email,$size='40').'</a></li>';
     }
     echo $mostactive;
     ?>
 </ul>

说明:核心部分就是代码中橙色部分代码,2010-09-01 00:00:00 是结束时间,43664 MINUTE 是指统计范围为 2010.9.1 0:00 前30天过7小时44分内,其实就是 2010.8.1 16:16 ~2010.8.31 24:00这个时段啦。

一些例子

1. 2010.8.18~2010.8.20内的读者墙:date_sub( '2010-08-20 00:00:00', INTERVAL 3 DAY)

2. 最近一周内:date_sub(NOW(), INTERVAL 1 WEEK)

……

====================================

附:SQL 的 date_sub() 函数

DATE_SUB() 函数从日期减去指定的时间间隔。

语法

DATE_SUB(date,INTERVAL expr type)

date 参数是合法的日期表达式;expr 参数是您希望添加的时间间隔。

Type 值

MICROSECOND
SECOND
MINUTE
HOUR
DAY
WEEK
MONTH
QUARTER
YEAR
SECOND_MICROSECOND
MINUTE_MICROSECOND
MINUTE_SECOND
HOUR_MICROSECOND
HOUR_SECOND
HOUR_MINUTE
DAY_MICROSECOND
DAY_SECOND
DAY_MINUTE
DAY_HOUR
YEAR_MONTH

====================================

OK,喜欢折腾的朋友慢慢折腾吧。

zww
or
oooo

“某段时间内的读者墙”有135条评论

  1. winy says:

    目前用不到,纯参与

  2. 丕子 says:

    以前用过一段时间读者墙

  3. 阿邙 says:

    要是能 每个月初都清零就好了

    1. 阿邙 says:

      @阿邙 WHERE comment_date > date_sub( NOW(), INTERVAL 1 MONTH )
      这句拿走了 :grin:

    2. 阿邙 says:

      @阿邙 不对 是这句:
      WHERE MONTH(comment_date)=MONTH(now()) and YEAR(comment_date)=YEAR(now()) :roll:

    3. zwwooooo says:

      @阿邙 对,这是按自然月

    4. 阿邙 says:

      @zwwooooo 恩 我正需要这种 嘿嘿

    1. zwwooooo says:

      @忘记浪漫 来我这就是来挖鼻子

  4. 我是来围观学习的...

  5. PARA says:

    还没弄个读者墙,先来了解一下 :eek:

    1. zwwooooo says:

      @PARA 用用也不错

  6. A.shun says:

    强势围观~
    果然帮助别人才是消灭文囧的王道 :cool:

  7. hzlzh says:

    记得最早你把时间写错了,嘎嘎~~~
    11楼的表情动起来有瑕疵,改下吧,完美的zww

    1. zwwooooo says:

      @hzlzh 做好后就发现了,懒啊,貌似也不是很多人喜欢这个表情

  8. 万戈 says:

    关键参数看明白了,闪人 :mrgreen:

  9. 我觉得按月统计比较合理,有些信息并不是越及时越好。

  10. 7cbt says:

    读者墙 想法非常不错。
    呵呵 木木木开始派发奖金,相信很多博友都会支持下吧

    1. 7cbt says:

      @zwwooooo 木木木不熟 ZW 你什么时候发奖金搞活动?

    2. zwwooooo says:

      @7cbt 我还等着人赞助我呢

  11. TTkea says:

    这个不错哟,呵呵~

  12. 博主乱搞都搞得这么有水平

    1. zwwooooo says:

      @最有效的祛斑产品 没什么,能用即可

  13. Dianso says:

    收藏了

  14. zzzhu says:

    这岂不更火了 呵呵

    1. zwwooooo says:

      @zzzhu 顺便友情广告一下

  15. 小邪 says:

    。。。。。看到那么长的sql语句,晕过去鸟 ~ (((φ(◎ロ◎;)φ)))

    1. zwwooooo says:

      @小邪 小邪不懂?其实我也不懂

  16. 樊文生 says:

    不错,考虑以后为Wepress也写个类似的插件 :mrgreen:

    1. zwwooooo says:

      @樊文生 嗯,很不错,移植吧

  17. zchiy2k says:

    最近读者墙都被各位wper搞出花来了~ :mrgreen:
    支持一下!

  18. 灰太狼 says:

    不错,考虑.考虑

  19. 读者墙很有用,呵呵我用了我友情链接的一个代码实现啦

    1. zwwooooo says:

      @软件盒子 很多种,看怎么折腾

发表评论

昵称 *

网址

B em del U Link Code Quote