Old

某段时间内的读者墙

前言:读者墙,我想大家都很熟悉了,目前网上流传的代码版本主要有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

声明: 除非注明,ZWWoOoOo文章均为原创,转载请以链接形式标明本文地址
本文地址: http://zww.me/archives/25228

135 comments

  1. 林木木 林木木 Google Chrome 6.0.479.0 Google Chrome 6.0.479.0 Windows 7 Windows 7

    杀呀!

    沙发
  2. bolo bolo Firefox 3.6.8 Firefox 3.6.8 Windows 7 Windows 7

    添加运算符的话应该可以变得更灵活的

    板凳
  3. 林木木 林木木 Google Chrome 6.0.479.0 Google Chrome 6.0.479.0 Windows 7 Windows 7

    用上后效果明显哟~

    地板
  4. ......
  5. 3q博客 3q博客 Firefox 3.6.8 Firefox 3.6.8 Windows 7 Windows 7

    这个用上了,谢谢分享

    61楼
  6. 绝版黑色 绝版黑色 Google Chrome 6.0.483.0 Google Chrome 6.0.483.0 Windows 7 Windows 7

    我在自己博客上面测试过各个版本的读者墙 没一个成功的,不知道是我个人原因, 还是主题的原因,相当恼火= =

    实在没法,只能放弃了 :evil:

    62楼
  7. FORECE FORECE Firefox 3.6.8 Firefox 3.6.8 Windows XP Windows XP

    观赏一下...

    63楼
  8. 呼噜卡 呼噜卡 Internet Explorer 6.0 Internet Explorer 6.0 Windows 2000 Windows 2000

    比较实用~ :wink:

    64楼
  9. QQ分组 QQ分组 Firefox 3.0.19 Firefox 3.0.19 Windows XP Windows XP

    很实用的东西啊!收藏!

    65楼
  10. 园子 园子 Firefox 3.6.8 Firefox 3.6.8 Windows XP Windows XP

    谢谢提供代码
    我试试去~

    66楼
  11. 求索阁 求索阁 360Safe Explorer 360Safe Explorer Windows XP Windows XP

    真爽牛人啊~!
    按照你的方法,添加成功。不过有一个问题:就是显示的范围超过了右边栏啊~~怎么设置呢? :?:

    67楼
  12. ADD~`` ADD~`` Google Chrome 6.0.495.0 Google Chrome 6.0.495.0 Windows 7 Windows 7

    如何让得到的结果不显示博主本身的呢? :?:

    68楼
    • ADD~`` ADD~`` Google Chrome 6.0.495.0 Google Chrome 6.0.495.0 Windows 7 Windows 7

      @ADD~``
      AND comment_author != $my_email这句貌似是根据邮箱不显示作者头像,但是我的不知道为啥- -不好使.. :???:

    • zwwooooo zwwooooo Google Chrome 7.0.517.17 Google Chrome 7.0.517.17 Windows 7 Windows 7

      @ADD~``
      不好意思,检查了一下,的确是搞错了,竟然现在才发现,很多人参考可能自己修正了,你把 comment_author 改为 comment_author_email

  13. 优趣 优趣 Google Chrome 9.0.576.0 Google Chrome 9.0.576.0 Windows 7 Windows 7

    支持下、!试试去

    69楼
  14. 断竹挽风 断竹挽风 Internet Explorer 8.0 Internet Explorer 8.0 Windows XP Windows XP

    还是这个好,限定时间。(请问下博主,如果显示有多少评论数,alt属性。)

    70楼
    • zwwooooo zwwooooo Namoroka 3.6.17 Namoroka 3.6.17 Windows 7 Windows 7

      @断竹挽风
      本身就会显示,当然ie下无效,要有效就要改造get_avatar()函数了

  15. SEV SEV Firefox 8.0 Firefox 8.0 Windows 7 Windows 7

    你的博客有很多好东西啊,谢谢分享

    71楼

Leave a Reply