温馨提醒

如果文章内容或图片资源失效,请留言反馈,我们会及时处理,谢谢

本文最后更新于2023年11月17日,已超过 180天没有更新

帝国cms调用相关文章有默认的调用标签方法:[otherlink],但是[otherlink]调用效率不高,不能满足所有情况下的相关调用,这里我们就需要自己写SQL了。

调用相关信息原理也就是依照一个字段条件,匹配他们的关联系了,下面我的站长站分享几种匹配方法的调用相关信息方法。

[otherlink]方法

[otherlink]标签模板ID,操作对象,调用条数,标题截取字数,是否显示栏目名,操作类型,只显示标题图片的信息[/otherlink]

SQL匹配截取标题关键词

<?php echo $navinfor[title]; $v= mb_substr($navinfor[title],0,4,'UTF-8');?> //获取当前文章标题,截取4个字符,并赋值给$v变量
[e:loop={"select * from phome_ecms_news where title like '%$v%' order by rand() desc limit 10",10,24,0}] //把$v加入到查询语句中,随机查询新闻表中title字段包含$v值的标题的文章,取出10条
<li><a href="<?=$bqsr['titleurl']?>" target="_blank">
<?=$bqr['title']?>
</a></li>
[/e:loop]

灵动标签匹配全标题

[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]){
$xgkey2=explode(",",$navinfor[keyboard]);
for ($i=0;$i<count($xgkey2);$i++){
    if ($i==0){
    $xg2.="keyboard like '%".$xgkey2[$i]."%' ";
    } else {
    $xg2.="or keyboard like '%".$xgkey2[$i]."%' ";
    }
}
$xgsql2=$empire->query("select * from {$dbtbpre}ecms_news where $xg2 and id!='$navinfor[id]' order by newstime desc limit 10"); 
while($xgs2=$empire->fetch($xgsql2)){
?>
          <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>
<?
}
}
?>
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。