下载鸥 > 网站下载 > 开发教程 > 帝国CMS

帝国cms怎样高效调用当前栏目推荐信息随机展示

494 2021-03-05 17:21:20

收藏
本文完全针对数据量至少在1万条以上的站点,如果站点数据不足1万条,不管是推荐、相关还是其他随机展示,完全可以用rand()做随机。

但数据量超过1万时,rand()函数非常消耗性能,轻则卡顿,重则卡死。数据量如果超过10万,绝不能在调用数据时用rand()。

那么,帝国cms怎样高效调用大数据站点当前栏目推荐信息随机展示呢?
 

1、取得全部推荐信息ID并随机选取要展示的ID

<?php
    $ecms_bq_sql=sys_ReturnEcmsLoopBq("select id from {$dbtbpre}ecms_$tbname where classid=$GLOBALS[navclassid] and isgood>0 order by id desc",20,24,0);
    while($bqr=$empire->fetch($ecms_bq_sql)){
           $bqsr=sys_ReturnEcmsLoopStext($bqr);
           $randids[] = $bqr[id];
    }
    shuffle($randids);
    $randids=array_slice($randids,0,10);
    $randids=implode(',',$randids);
?>
以上php源码主要目的在于获取当前栏目全部推荐信息,并随机取10条,与rand()相比免去了mysql循环查库并随机的过程,效率高之不少。

如果网站数据量很大,例如超过10万,则上方SQL命令需要进行一定程度的限制(会导致不是完全随机),否则同样会导致速度慢。
 

2、调用指定的随机ID做展示

[e:loop={"SELECT titleurl,title from [!db.pre!]ecms_news where id in ($randids) LIMIT 10",10,24,0}]
<li><a href="<?=$bqr[titleurl]?>" target="_blank" title="<?=$bqr[title]?>"><?=$bqr[title]?></a></li>
[/e:loop]

通过这样的方式,我们就可以实现高效调用推荐信息了,尤其是百万、千万级数据量的站点,千万不要用rand()。虽然简单,却损耗了超过300%的性能。

在前面的文章中,我们介绍了帝国CMS做百万、千万级别数据库的网站的相关信息,而一个千万级数据的站点要用到随机,是肯定不能用rand()的。

本文地址:https://xzo.com.cn/develop/empire/662.html

有帮助,很赞!

信息来源:下载鸥
导出教程 下载word版教程
发表评论 共有条评论
  • 隐藏的大佬 2021-05-11 04:28:11评论 #沙发#

    牛逼!网上那么多随机调用方案都长一个样,但根本就不合理,明眼人一看就懂。这个方案我虽然不是很理解原理,但确实很高效,而且数据也没有问题!感谢大佬无私分享!

关于帝国CMS


帝国cms是一款功能极为强大的cms程序,性能强悍、安全性高,可轻松支持10万数据,高级开发人员可制作出能容纳千万数据量的网站,是国内最出色的开源cms程序之一,推荐企业用户使用

当前最新版本为7.5,8.0版本即将上线,新版本的核心优化点在于多终端的适配。

推荐帝国CMS开发教程
帝国cms文章列表、详情怎样实时显示点击数?
帝国cms文章列表、详情怎样实时显示点击数?

常有客户要求文章列表、详情能够实时显示点击数,但又不想将静态页面改为动态...

6 572
帝国cms制作信息反馈表的方法
帝国cms制作信息反馈表的方法

帝国cms自带的信息反馈功能,不仅可以实现留言功能,还可以实现像在线报名、反...

1 579
帝国cms怎样做下载日、周、月排行功能?
帝国cms怎样做下载日、周、月排行功能?

帝国cms开发的下载站很多,许多站点基于优质用户推荐的需求就需要做下载的日...

3 450
帝国cms备份的数据存储在哪个文件夹?
帝国cms备份的数据存储在哪个文件夹?

有些时候,我们需要备份数据并取出来,此时从哪里去取呢?帝国cms备份的数据存储...

1 867
帝国CMS+jquery简单实现点击图片进入下一页功能
帝国CMS+jquery简单实现点击图片进入下一页功能

使用js实现点击按钮进入下一个内容页分页,用jQuery做肯定是最快捷的方式,因此...

1 417
帝国cms某个栏目使用完全自定义的分页功能
帝国cms某个栏目使用完全自定义的分页功能

帝国CMS列表页的分页函数是用系统设置中的分页函数,修改都是在系统设置里进...

0 757
帝国cms怎样去掉面包屑导航里的隐藏栏目
帝国cms怎样去掉面包屑导航里的隐藏栏目

帝国cms有隐藏栏目的功能,但隐藏栏目的文章如果展示,面包屑导航里会带上被隐...

1 680
帝国cms提取正文里的3张图片做缩略图
帝国cms提取正文里的3张图片做缩略图

帝国cms怎样提取正文里的3张图片做缩略图呢?...

0 685
推荐插件
帝国cms在线考试系统模板插件
帝国cms在线考试系统模板插件

一直没看到好用的帝国cms在线考试插件,所以自己开发了一款。在线考试插件用...

0 1297
帝国cms百度AI图像清晰度增强api接口对接插件
帝国cms百度AI图像清晰度增强api接口对接插件

通过本插件,可以实现帝国cms网站对接百度云api实现图像清晰度增强的功能。经...

0 531
帝国cms联想词搜索高级搜索插件下载
帝国cms联想词搜索高级搜索插件下载

帝国CMS自带的搜索功能虽然强大,但也有很强的局限性 -- 必须关键词完全匹配...

0 743
帝国cms百度AI图像去雾api接口对接插件
帝国cms百度AI图像去雾api接口对接插件

通过本插件,可以实现帝国cms网站对接百度云api实现图像去雾的功能。经过实际...

0 467
帝国CMS内网用户静态站点文章访客统计插件
帝国CMS内网用户静态站点文章访客统计插件

本插件适用于内网用户,可查看单篇文章访问者ip地址。如果添加访问者ip组,可查...

0 571
帝国cms网站会员登录与退出历史记录日志插件
帝国cms网站会员登录与退出历史记录日志插件

帝国cms默认只有上次登录时间与ip,没有一个记录清单,所以今天,我们分享这个帝...

0 415
帝国cms访问统计ip地址链接与封禁插件下载
帝国cms访问统计ip地址链接与封禁插件下载

下载鸥开发了这款帝国cms封禁ip插件,自动记录访问情况,让我们可以更快的识别...

0 1028
帝国cms自动生成文章新闻目录插件下载
帝国cms自动生成文章新闻目录插件下载

用户体验是我们的需求,百度蜘蛛的认可更是我们的需求。毕竟,没有收录排名,何来...

0 1135
客服QQ:341553759
扫码咨询 常见问题 >
官方交流群:90432500
点击加入