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

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

563 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列表页怎样置顶?

在很多时候,我们有信息置顶的需求。但大家在后台信息设置好置顶后可能会发现...

11 934
PHPCMS可以转为帝国CMS程序吗?
PHPCMS可以转为帝国CMS程序吗?

如今phpcms由于停止更新不能继续用下去了,我们就更加推荐帝国。那么,phpcms可...

23 949
帝国cms怎样将信息来源befrom外链转内链?
帝国cms怎样将信息来源befrom外链转内链?

很多技术分享型站点转载了外站不少信息,部分有素质的站长会展示信息来源并链...

27 4087
帝国CMS生成选项是“ID目录”无斜扛解决的方法
帝国CMS生成选项是“ID目录”无斜扛解决的方法

如果你栏目生成选项选择的ID目录,那么帝国他生成的地址会少一个斜扛,访问时就...

3 554
帝国cms会员中心查看评论过的文章怎么开发?
帝国cms会员中心查看评论过的文章怎么开发?

许多帝国cms站点开放了会员评论的功能,而评论过的文章可以查看则相当于当年...

1 490
帝国CMS怎样验证后台发布信息标题是否重复?
帝国CMS怎样验证后台发布信息标题是否重复?

想要在帝国cms后台禁止发布标题相同的信息,或是在发布信息时验证一下标题是...

2 817
帝国cms怎样判断文章有没有缩略图?
帝国cms怎样判断文章有没有缩略图?

在帝国cms二次开发过程中,我们有时会需要判断一条信息有没有缩略图(标题图)。...

0 474
帝国cms怎样关闭评论验证码?
帝国cms怎样关闭评论验证码?

帝国cms网站评论验证码是一个很重要的功能,有验证码才能挡住大量的灌水信息...

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

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

0 500
帝国cms百度AI图像无损放大api接口对接插件
帝国cms百度AI图像无损放大api接口对接插件

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

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

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

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

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

0 665
帝国cms纳米数据接口(足球比赛中最新数据)
帝国cms纳米数据接口(足球比赛中最新数据)

帝国cms 对接纳米数据(www.nami.com)接口,本接口主要接收、整理足球比赛实时数...

0 581
帝国cms百度AI黑白图像上色api接口对接插件
帝国cms百度AI黑白图像上色api接口对接插件

百度开放了系列AI功能api如图像上色、图像去雾、图像修复、无损放大、清晰...

0 527
帝国cms批量添加后台用户插件
帝国cms批量添加后台用户插件

使用帝国cms的企业用户、新闻资讯类站点的用户很多,此类站点很多时候需要有...

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

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

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