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

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

374 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开发教程
PHPCMS可以转为帝国CMS程序吗?
PHPCMS可以转为帝国CMS程序吗?

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

23 774
帝国CMS留言板怎样增加字段?
帝国CMS留言板怎样增加字段?

网站留言板是用户留存的重要环节,但帝国cms自带的留言板功能十分单一,大多数...

1 304
帝国cms制作信息反馈表的方法
帝国cms制作信息反馈表的方法

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

1 438
帝国cms误删了已收录的文章要怎么恢复数据?
帝国cms误删了已收录的文章要怎么恢复数据?

客户站点由于员工操作失误,直接删除了20篇文章。如果有定期备份,那恢复数据即...

0 359
帝国cms自动更新相关tag的fclast上次修改时间字段
帝国cms自动更新相关tag的fclast上次修改时间字段

每次更新发布文章tag信息后,tag数据表的时间会自动同步,但tag信息表的修改时...

0 318
帝国cms把自己ip禁止访问了怎么办?
帝国cms把自己ip禁止访问了怎么办?

帝国cms有禁止ip访问的功能,但如果不小心禁止了自己的ip,或是操作失误导致所...

0 606
帝国cms网站怎样判断是动态、静态还是伪静态?
帝国cms网站怎样判断是动态、静态还是伪静态?

对于资深一点的站长或者SEO来说,一定会经常听到动态、静态、伪静态这类的词...

0 440
怎样提高帝国cms的生成刷新效率?
怎样提高帝国cms的生成刷新效率?

帝国cms是一款功能强大的cms,不仅安全性高,还能够轻松驾驭20万以上的数据,牛逼...

1 423
随机帝国CMS开发教程
帝国CMS怎样高效快速的做猜你喜欢的随机调用功能?
帝国CMS怎样高效快速的做猜你喜欢的随机调用功能?

猜你喜欢小功能如果直接用rand()调用随机ID是非常消耗性能的。小网站几百几...

7 370
帝国CMS首页、列表页实现点赞功能解析与demo
帝国CMS首页、列表页实现点赞功能解析与demo

帝国cms的点赞数是通过动态脚本载入的方式实时输出,而a标签上的makeRequest(...

1 322
帝国cms的fetch()和fetch1()有什么区别?
帝国cms的fetch()和fetch1()有什么区别?

fetch()和fetch1()是帝国CMS二次开发常用到的函数,虽然只差了一个1,但其函数...

7 520
帝国cms后台出现“您还未登录”错误怎么办
帝国cms后台出现“您还未登录”错误怎么办

帝国cms测试多次,绝对是正确的用户名和密码登录,但还是显示您还未登录的原因...

3 365
帝国cms文章列表、详情怎样实时显示点击数?
帝国cms文章列表、详情怎样实时显示点击数?

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

6 461
帝国CMS 8.0版本即将上线,届时不再支持GBK、BIG5编码
帝国CMS 8.0版本即将上线,届时不再支持GBK、BIG5编码

3月1日上午10点,帝国cms创始人王猛发布微博称8.0版本不再支持gbk、big5编码...

8 551
帝国CMS灵动标签调用留言板信息(附留言板字段解读)
帝国CMS灵动标签调用留言板信息(附留言板字段解读)

帝国cms调用留言板信息是可以调用到任意位置的,灵动标签即可办到。通过通配...

10 527
帝国cms怎样开发下载分成功能?
帝国cms怎样开发下载分成功能?

帝国CMS下载分成网上有很多插件,但操作起来都相对比较复杂,且免费插件存在安...

17 540
客服QQ:341553759
点击咨询 常见问题 >
官方交流群:90432500
点击加入