改一下wordpress相关文章的获取方式

看了露兜兄的相关文章代码,果然比我这种对PHP半懂不懂的人高明多了。本来之前我打算用老式方法:靠标签获得相关文章,不过现在我有了个新想法。

因为我在google上site我的站的时候,发现一个不好的现象,排在前面的通通是大量标签的页面,而真正的文章内容页却少得可怜。我觉得这不是一个好的现象,所以我打算以后写文章都不加标签了,更以后之后我会直接删掉所有标签。

这样一来显然靠标签获取相关文章就会找不到,所以我打算用上面的文章里的另一种办法,靠相同分类获取。现在让我静观其变吧 。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<ul id="cat_related">
<?php
global $post, $wpdb;
$cats = wp_get_post_categories($post->ID);
if ($cats) {
  $related = $wpdb->get_results("
  SELECT post_title, ID
  FROM {$wpdb->prefix}posts, {$wpdb->prefix}term_relationships, {$wpdb->prefix}term_taxonomy
  WHERE {$wpdb->prefix}posts.ID = {$wpdb->prefix}term_relationships.object_id
  AND {$wpdb->prefix}term_taxonomy.taxonomy = 'category'
  AND {$wpdb->prefix}term_taxonomy.term_taxonomy_id = {$wpdb->prefix}term_relationships.term_taxonomy_id
  AND {$wpdb->prefix}posts.post_status = 'publish'
  AND {$wpdb->prefix}posts.post_type = 'post'
  AND {$wpdb->prefix}term_taxonomy.term_id = '"
. $cats[0] . "'
  AND {$wpdb->prefix}posts.ID != '"
. $post->ID . "'
  ORDER BY RAND( )
  LIMIT 6"
);
  if ( $related ) {
      foreach ($related as $related_post) {
?>
    <li><a href="<?php echo get_permalink($related_post->ID); ?>" rel="bookmark" title="<?php echo $related_post->post_title; ?>"><?php echo $related_post->post_title; ?></a></li>
<?php
    }
  }
  else {
    echo '<li>暂无相关文章</li>';
  }
}
else {
  echo '<li>暂无相关文章</li>';
}
?>
</ul>

《改一下wordpress相关文章的获取方式》有1个想法

发表评论

电子邮件地址不会被公开。