某段时间内的读者墙

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

    读者墙~?爱月觉得jinwen做的还是不错的,毕竟是友链里的链接才上墙,这样可以阻止人肉垃圾评论

    1. zwwooooo says:

      @爱月 jinwen?他那里哪里有读者墙?

  2. yetone says:

    你太牛了,乱撞都能弄好,令我羡慕加嫉妒

    1. zwwooooo says:

      @yetone 这……乱撞也要懂丁点儿

  3. 苏扬 says:

    SQL下 这个 -> 是什么意思?

    1. zwwooooo says:

      @苏扬 其实我是不懂的,按照样子来看是从左边那个数组取出右边的子数组

  4. 也 太厉害鸟 这样也成呢 :grin:

    1. zwwooooo says:

      @指舞六弦 哈哈,能用则行

  5. 乱撞都能弄好 佩服...

  6. 郑永 says:

    我看这奖金大礼应该少不了咱们的zwwo兄弟,对吧,不然的话,干脆把代码改下,让你的头像直接排第一,哈哈。

    1. zwwooooo says:

      @郑永 你搞错了,我不参与,纯粹友情

  7. :razz: 我太佩服zww童鞋了,哦,我正要折腾下文章内的图片,如何限制上传后的大小呢,就是编辑文章时上传的图片,想把 大 中 小 图片的宽高进行修改,这个如何改呢,昨天bdgg了半天楞是没有找到合适的

    1. zwwooooo says:

      @指舞六弦 wp自带编辑器不是可以设置么?上传插入图片到文章后,点击图片属性-》高级属性那里就有设置鸟

    2. @zwwooooo
      但是我想把这个重新设置宽高,因为他那个根据图片设置的,要么太大,要么太小,汗

    3. zwwooooo says:

      @指舞六弦 wp后台有个媒体选项,你去那里这是

  8. 琉雅 says:

    嗯,非常不错。。。。

  9. Bee君 says:

    哈哈,运气感太好了吧~

    这个就是作用与某个时间段内的读者统计,,在某些活动中很有作用呢..不过一看到折腾就心烦了~~啊啊啊啊~ :evil:

    1. zwwooooo says:

      @Bee君 那就直接用 :mrgreen:

  10. 不错,还可以,可是、、、、下次能不能不要乱撞。嘻嘻、、、、

    1. zwwooooo says:

      @磁粉离合器 不乱撞就折腾不出来了,因为懒啊

  11. countmeon says:

    呵呵 这个还是不错的

  12. 木本无心 says:

    有奖金发啊,口水……
    话说我的pjblog的读者墙马上就要出炉了啊,哈……

    1. zwwooooo says:

      @木本无心 很好,PJer有福了

  13. 物业管理人才网 says:

    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 != $my_email
    AND post_password=''
    AND comment_approved='1'
    AND comment_type='http://qq.pinpaijia.com') AS tempcmt GROUP BY comment_author_email
    ORDER BY cnt DESC LIMIT $limit_num

    这个是java的语言么?怎么有点看不懂类。

  14. 呵呵 这个还是不错的

  15. 樊文生 says:

    这个功能很不错~~

  16. 有点意思啊~~

  17. zzzhu says:

    挣上你的读者强 呵呵

  18. 山水画 says:

    呵呵,不错

  19. Fanr says:

    好东东啊~~~

  20. 3q博客 says:

    这个用上了,谢谢分享

    1. zwwooooo says:

      @3q博客 荒淫使用

发表评论

昵称 *

网址

B em del U Link Code Quote