【性能不错的手机】性能不错的sql获取相关文章方法

更新时间:2019-11-21    来源:php与数据库    手机版     字体:

【www.bbyears.com--php与数据库】

用sql获取相关文章不要单纯去用select * from article where catid=** and aid<>**; 这样每篇文章获取的相关文章是固定的,不利于体验和seo。

推荐获取当前文章的前几篇和后几篇,这样每篇文章都有显示的机会,代潇瑞博客的相关文章就是这样的算法。

sql参考范例(php语言):

$rArt1 = $db->query('select * from article where catid=$catid and aid<$aid order by aid desc limit 0,4');
$rArt2 = $db->query('select * from article where catid=$catid and aid>$aid order by aid asc limit 0,4');

if( !empty($rArt1) && !empty($rArt2) ) {
    $relationArt = array_merge($rArt1, $rArt2);
}
else {
    $relationArt = empty($rArt1) ? $rArt2 : $rArt1;
}

即获取当前文章相邻的8篇文章,当文章处于最后一篇,或者最前一篇,那它只有前部分或后部分4篇相关文章。其实这里可以做判断,让它取足8篇相关文章,这就看自己的需求了。


WordPress代码实现相关文章的五种方法比较

WordPress很多插件可以实现相关文章的功能,插件的优点是配置简单,但是可能会对网站的速度造成一些小的影响,所以很多人还是比较喜欢用代码实现需要的功能,但是话又说回来了,代码实现也有缺点,就是配置复杂,不懂代码的人完全摸不着头脑或者只能照搬别人的代码,还不如用插件。

这里我整理编写了几种用代码实现相关文章的方法,这其中会详细标明各部分代码的作用,以及如何自定义你想要的功能,希望对大家有所帮助,有什么问题可以给本文发表评论,我会及时给你回复。开始之前,说明一点,以下所有方法输出的HTML代码格式都是以下形式,你可以根据需要进行修改:


        * 文章标题1
        * 文章标题2
        ......


    方法一:标签相关

    首先获取文章的所有标签,接着获取这些标签下的 n 篇文章,那么这 n 篇文章就是与该文章相关的文章了。现在可以见到的WordPress相关文章插件都是使用的这个方法。下面是实现的代码: