帝国cms调用相关文章灵动标签语句方法
时间:2023年07月04日
/来源:网络
/编辑:佚名
帝国cms调用相关文章的一些标签使用方法以及灵动标签调用相关文章的写法...
帝国cms默认的相关文章[otherlink]调用效率一点也不高,不能满足理想功能下所有情况下的调用。
我们可以用以下的SQL语句以及灵动标签写法来实现想要的功能:
1、SQL匹配标题关键词
<?php $f= mb_substr($navinfor[title],0,4,'UTF-8');?> //截取当前文章标题4个字符,并赋值给$f变量
[e:loop={"select * from www_kaifamei_com_ecms_news where title like '%$f%' order by rand() desc limit 10",10,24,0}] //随机查询截取的关键词在新闻表中的10条数据随机显示
<li><a href="<?=$bqsr['titleurl']?>" target="_blank">
<?=$bqr['title']?>
</a></li>
[/e:loop]
2、用灵动标签来调用
[e:loop={'news',10,3,0,"title like '%$navinfor[title]%'",''}]
<li>·<a href="<?=$bqsr['titleurl']?>" target="_blank"><?=esub($bqr[title],24)?></a></li>
[/e:loop]
其中匹配的方式可以作修改,根据自身需要以及优缺点选择。
标题匹配:
比较粗糙的匹配,可能不太精确:title like '%$navinfor[keyboard]%'
精确的匹配,比较消耗资源:title regexp '(^|,)$navinfor[keyboard]($|,)'
关键字匹配:
比较粗糙的匹配,可能不太精确:keyboard like '%$navinfor[keyboard]%'
精确的匹配,比较消耗资源:keyboard regexp '(^|,)$navinfor[keyboard]($|,)'
修改双引号中的为以上的就可以。
进行适当的估化,当没有匹配到相关内容的时候自动用最新的内容来代替可以用以下代码:
<?
if ($navinfor[keyboard]){
$key=explode(",",$navinfor[keyboard]);
for ($i=0;$i<count($key);$i++){
if ($i==0){
$xgword.="keyboard like '%".$key[$i]."%' ";
} else {
$xgword.="or keyboard like '%".$key[$i]."%' ";
}
}
$wordsql=$empire->query("select * from {$dbtbpre}ecms_news where $xgwordand id!='$navinfor[id]' order by newstime desc limit 10");
while($xgk2=$empire->fetch($wordsql)){
?>
<h2><a href="<?=$xgs2['titleurl']?>" title="<?=$xgs2['title']?>"><strong><?=$xgs2['title']?></strong></a></h2>
<?
}
}
else{
$tsql=$empire->query("select * from {$dbtbpre}ecms_news order by newstime desc limit 10");
while($r=$empire->fetch($tsql)){
?>
<h2><a href="<?=$r['titleurl']?>" title="<?=$r['title']?>"><strong><?=$r['title']?></strong></a></h2>
<?
}
}
?>
以上就是相关文章的一些调用方法了。
帝国cms默认的相关文章[otherlink]调用效率一点也不高,不能满足理想功能下所有情况下的调用。
我们可以用以下的SQL语句以及灵动标签写法来实现想要的功能:
1、SQL匹配标题关键词
<?php $f= mb_substr($navinfor[title],0,4,'UTF-8');?> //截取当前文章标题4个字符,并赋值给$f变量
[e:loop={"select * from www_kaifamei_com_ecms_news where title like '%$f%' order by rand() desc limit 10",10,24,0}] //随机查询截取的关键词在新闻表中的10条数据随机显示
<li><a href="<?=$bqsr['titleurl']?>" target="_blank">
<?=$bqr['title']?>
</a></li>
[/e:loop]
2、用灵动标签来调用
[e:loop={'news',10,3,0,"title like '%$navinfor[title]%'",''}]
<li>·<a href="<?=$bqsr['titleurl']?>" target="_blank"><?=esub($bqr[title],24)?></a></li>
[/e:loop]
其中匹配的方式可以作修改,根据自身需要以及优缺点选择。
标题匹配:
比较粗糙的匹配,可能不太精确:title like '%$navinfor[keyboard]%'
精确的匹配,比较消耗资源:title regexp '(^|,)$navinfor[keyboard]($|,)'
关键字匹配:
比较粗糙的匹配,可能不太精确:keyboard like '%$navinfor[keyboard]%'
精确的匹配,比较消耗资源:keyboard regexp '(^|,)$navinfor[keyboard]($|,)'
修改双引号中的为以上的就可以。
进行适当的估化,当没有匹配到相关内容的时候自动用最新的内容来代替可以用以下代码:
<?
if ($navinfor[keyboard]){
$key=explode(",",$navinfor[keyboard]);
for ($i=0;$i<count($key);$i++){
if ($i==0){
$xgword.="keyboard like '%".$key[$i]."%' ";
} else {
$xgword.="or keyboard like '%".$key[$i]."%' ";
}
}
$wordsql=$empire->query("select * from {$dbtbpre}ecms_news where $xgwordand id!='$navinfor[id]' order by newstime desc limit 10");
while($xgk2=$empire->fetch($wordsql)){
?>
<h2><a href="<?=$xgs2['titleurl']?>" title="<?=$xgs2['title']?>"><strong><?=$xgs2['title']?></strong></a></h2>
<?
}
}
else{
$tsql=$empire->query("select * from {$dbtbpre}ecms_news order by newstime desc limit 10");
while($r=$empire->fetch($tsql)){
?>
<h2><a href="<?=$r['titleurl']?>" title="<?=$r['title']?>"><strong><?=$r['title']?></strong></a></h2>
<?
}
}
?>
以上就是相关文章的一些调用方法了。
新闻资讯 更多
- 【帝国cms教程】帝国CMS模板变量$GLOBALS[navclassid]用法分析04-03
- 【帝国cms教程】鲜为人知帝国CMS内容页调用上一篇和下一篇的精华方法汇总04-03
- 【帝国cms教程】怎么快速找出帝国CMS数据库配置文件路径及迁移网站后修改技巧!04-03
- 【帝国cms教程】帝国CMS模板$GLOBALS[navclassid]用法详解04-03
- 【帝国cms教程】帝国cms 7.5版列表页分页样式修改笔记04-02
- 【帝国cms教程】解决帝国CMS搜索页面模板不支持灵动标签和万能标签的方法04-02
- 【帝国cms教程】帝国CMS只备份栏目和模板的方法04-02
- 【帝国cms教程】帝国CMS怎样删除清空数据库记录?04-02
热门文章
- 178Moban源码谈谈免费源码与收费源码的区别
- 2帝国CMS忘记后台登陆用户名、密码、认证码的解决方法
- 3帝国CMS(EmpireCMS) v7.5后台任意代码执行漏洞及具体修复方法
- 4帝国CMS和WordPress 哪个好?哪个适合建站?
- 5如何解决Discuz的密码错误次数过多请15分钟后登陆的问题
- 6帝国cms灵动标签取得内容和栏目链接地址
- 7emlog pro 注册码“开心”教程(如果有一天,emlog官方版 或者 emlog免费版 跑路了,那用户怎么办?)
- 8织梦CMS在nginx下设置伪静态方法(附nginx伪静态规则)
- 9帝国cms后台登录出现”您还未登录”怎么解决?
- 10帝国cms7.5忘记登录密码 和忘记登录认证码以及多次登录 失败被锁定解决办法