您当前的位置: 主页 > 优化教程
本文实例讲述了dedecms使用sql语句调用文章静态链接地址的方法。分享给大家供大家参考。具体分析如下:
 
很多时候我们用织梦后台调用数据的时候,自带的标签很多时候都没办法调用我们要的数据,因此要自己写sql去调用,之前有个问题搞了两天都没搞出来,后来看到下面这个文章,问题解决了.
 
使用dedecms这个程序建站有五年多的时间了,期间建了不少网站,欢迎各位朋友找我建站.
 
补充:
 
发布这篇文章后,无意间发现在了dedecms的GetOneArchive,只要传入一个文档id就可以获得文章链接了,其实这个函数返回的的文章信息数组包含了:链接地址,标题,文章ID,栏目ID,这里只需要文章链接地址,具体代码如下:
 
复制代码代码如下:{dede:sql sql="select * From dede_archives a where a.title like '%织梦建站%' and a.arcrank>-1 limit 8"}
 
<</code>li><</code>a title="[field:title/]" href="[field:id runphp='yes']$url=GetOneArchive(@me);@me=$url['arcurl'];[/field:id]">[field:title runphp='yes']@me=cn_substr(@me, 50);[/field:title]</</code>a></</code>li>
 
{/dede:sql}
 
如果你仅仅需要调用文章的链接地址该方法不失为一个快捷的方法,文章下部分介绍的方法较为复杂,但如果你想调用文章链接地址的同时还想调用栏目名称不妨试下.
 
为什么要使用dede:php,dede:sql
 
在一些比较复杂的调用中用dede:arclist标签是解决不了问题的,比如说大家常说的调用某一会员发布的文章等等之类,这些一般要通过dede:sql标签来实现.
 
今天我所说的调用也是比较特殊的就是在首页调用指定关键字的文章,其实这个跟dedecms的相关文章标签类似,这里给大家分享两种方法.
 
dede:sql标签调用指定关键字文章静态地址,这里引用dedecms官方关于dede:sql的介绍.
 
Sql标记
 
功能说明:用于从模板中用一个SQL查询获得其返回内容。
 
适用范围:非扩展模块所有模板。
 
(1)语法:{dede:sql sql="这里写sql语句"}底层模板{/dede:sql}
 
(2)属性:[1] sql 完整的SQL查询语句。
 
(3)底层模板:SQL语句中查出的所有字段都可以用[field:字段名/]来调用。
 
好了了解dede:sql标签后,就可以根据自己的需求写sql语句了,我这里是要调用指定关键字的文章,sql语句如下:
 
复制代码代码如下:"select * From dede_archives a where a.arcrank>-1 and a.title like '%脚本%' limit 8"
 
语句解析:a.arcrank>-1限制调用已审核的文章;like '%脚本%'调用指定关键字的文章;limit 8为调用条数为8条
 
然后就开始写完整的标签和底层模板了,如下:
 
1、首先解决完整标题和截字问题:我使用的是[field:title runphp='yes']@me=cn_substr(@me, 50);[/field:title]这种方法相信大家也经常用到,这里就不多作介绍了,以后可能会专门弄个文章介绍这种用法。50就是截字长度
 
2、解决dede:sql标签静态文章地址问题:这里比较麻烦了,我在网上转了一下,多数给出的解决办法就是href="/plus/view.php?aid=[field:id/]",显然这不是我想要的这不是静态地址,而其他地址用arclist调用的又是静态地址,结果就成了一篇文章有两个地址一个静态一个动态,这对seo来说显然不友好,最好通过自己折腾终于成功了
 
3、解决id不能正确获取的问题:之前没注意到因为dede_arctype和dede_archives两个表id字段名是一样的,以至于底层模板获取不到正确的id,之前select改了下,增加了别名。
 
dede:sql调用文章静态链接地址的完美方法
 
复制代码代码如下:{dede:sql sql="select * From dede_archives a, dede_arctype t where a.typeid = t.id and a.title like '%生活小窍门%' and a.arcrank>-1 limit 8"}
 
<</code>li><</code>a title="[field:title/]" href="[field:array runphp='yes'] @me=GetFileUrl(@me['id'],@me['typeid'],@me['senddate'],@me['title'],@me['ismake'],@me['arcrank'],@me['namerule'],@me['typedir'],@me['money']); [/field:array]">[field:title runphp='yes']@me=cn_substr(@me, 50);[/field:title]</</code>a></</code>li>
 
{/dede:sql}
 
不管怎么说总算还是实现了我想要的效果,后来想了想用dede:php标签如何实现这个效果呢,其实方法和dede:sql标签是一样的,也就不多说什么了,直接贴代码:
 
复制代码代码如下:{dede:php}
 
$dsql->SetQuery("select a.id as aid, t.id as tid,typeid,senddate,title,ismake,arcrank,namerule,typedir From dede_archives a, dede_arctype t where a.typeid = t.id and a.title like '%生活小窍门%' and a.arcrank>-1 limit 8");
 
$dsql->Execute();
 
while($row = $dsql->GetArray()){
 
echo '<</code>li><</code>a title="'.$row['title'].'" href="'.GetFileUrl($row['aid'],$row['typeid'],$row['senddate'],$row['title'],$row['ismake'],$row['arcrank'],$row['namerule'],$row['typedir'],$row['money']).'">'.cn_substr($row['title'], 50).'</</code>a></</code>li>';
 
}
 
{/dede:php}
 
希望本文所述对大家的dedecms建站有所帮助。
 

关键词:织梦,dedecms,使用,sql,语句,调用,文章,静态,    标签:
    更多资讯请收藏关注 网站模板(www.1yc.cn)

DedeCMS织梦模板在PHP7.0以上环境下文章页空白怎么办?最近在捣腾阿里云服务器,发现把php版本升级到7.0之后,其他地方都是... 2021-07-22
织梦dedecms LOOP语句调用自定义表单内容的实现在使用edecms的过程中通常会要用到LOOP语句 这里我们将要说到的... 2021-07-22
织梦DEDECMS中的默认文件夹的名称怎么修改呢?1.首先找到系统配置文件,一般此文件会存放在Include目录下,文件... 2021-07-22
dedecmsdedecms不能保存jpeg格式图片的解决方法方法如下: 进入织梦的后台管理目录,默认是dede文件夹,找到/inc... 2021-08-09
DedeCMS织梦会员中心更改重新发邮件验证提醒的间隔时间由于最近在接了些私活,有些朋友就有这样一个需求,在织梦会员中心里面如何... 2021-07-30
织梦添加一个函数,实现任意字段调用先上代码 function table($table, $field,... 2021-07-27
dede织梦channelartlist高亮并且让嵌套标签里的channeldede:channelartlist标签当前栏目高亮实现教程 打开 ... 2021-07-22
织梦自定义模型中新增的字段会报错 Call to a member function GetInnerText() o在织梦自定义模型后,可能会报下面这个错误,Fatal error: C... 2021-07-27
织梦标签不能嵌套的2种解决方法我们用织梦建站时,嵌套标签,标签原封不动的被展示了出来而未被解析,举个... 2021-07-22
织梦CMS实现复制文章自动加出处信息假如发现自己辛苦创作的很多文章被别人复制或者采集而去,一个链接都不留下... 2021-08-14
dedecms优化之如何禁止dedecms搜索隐藏栏目内容在用dedecms建站时,很多时候都要用到隐藏栏目,而dedecms自... 2021-08-09
Dedecms:pagebreak 分页控制数量很多织梦建站的朋友会碰到这样的问题,想让内容页分页的样式变成和列表一样... 2021-07-27
怎么样解决织梦DEDECMS幻灯片图片显示模糊问题的办法大家使用织梦dedecms建站,都会遇到这样一个问题,就是织梦dede... 2021-08-14
XML站点地图:为什么URL排序很重要seo会争论很多事情——做这个,不做那个,这个有影响,那个没有。除了百... 2023-05-29
DedeCms获取当前页面URL地址的实现方法本文实例讲述了DedeCms获取当前页面URL地址的实现方法。分享给大... 2021-07-27
织梦dede编辑器附件和自定义字段附件上传文件点击无反应dede编辑器上的【附件】或者自定义字段【附件类型】,刚刚上传的文件不... 2021-07-22
织梦DEDECMS添加或修改文章出现空白解决办法织梦cms后台添加文章出现空白的解决办法: 后台=系统=系统设置=系统... 2021-07-22
DedeCMS文章标题长度最全修改方法有时候DedeCMS首页或者其他页面不能全部展示文章标题,造成读者阅读... 2021-08-14

线
咨询热线:
135-0038-3336
在线客服:
点击这里给我发消息
微信交流:
公司官网: www.1yc.cn