您当前的位置: 主页 > 优化教程
很多时候我们用织梦后台调用数据的时候,自带的标签很多时候都没办法调用我们要的数据,因此要自己写sql去调用,之前有个问题搞了两天都没搞出来,后来看到下面这个文章,问题解决了! 
使用dedecms这个程序建站有两年多的时间了,期间建了不少网站不过至今没有一个网站赚钱的,痛苦啊。可能平时花太多的时候在折腾网站上面,而没有用心去推广宣传。喜欢折腾没办法,不然也就没有以下的内容分享给大家了。 
补充:发布这往篇文章后,无意间发现在了dedecms的GetOneArchive,只要传入一个文档id就可以获得文章链接了,其实这个函数返回的的文章信息数组包含了:链接地址,标题,文章ID,栏目ID,这里只需要文章链接地址。具体代码如下 
{dede:sql sql="select * From dede_archives a where a.title like '%<a href="http://www.qmtx3.com/live/" target="_blank">生活</a>小<a href="http://www.qmtx3.com" target="_blank">窍门</a>%' and a.arcrank>-1 limit 8"}<li><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]</a></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条 
然后就开始写完整的标签和底层模板了,如下: 
这样就OK了?起初我也以为就是这么简单,兴奋的打开预览页面,靠,title="",href=""这两个属性都是空的,想一下算是明白了。dede:sql标签其实就是通过sql查询数据库返回查询的字段(注:这里我查询的字段为*,你可以根据你的实际情况来查询),底板模板中的[field:字段名称]调用的就是这个返回的字段,这些字段是没有经过任何程序处理的,直接就是数据库里的内容。比如说fulltitle,arcurl这个在数据库中就没有这两个字段,平常我们在dede:arclist中用到的这些字段只不过是dede在php程序中处理的。知道了问题所在然后查了下资料终于解决了。 
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"}<li><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]</a></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 '<li><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).'</a></li>'; 
    } 
{/dede:php} 
  
后的叼叼,dedecms个人觉得做一般的文章资讯类站点还是够用的,不过要做什么会员、下载。。。这些功能的站,dedecms貌似不怎么能胜任,就像dede:php,dede:sql这些标签,新手站长肯定搞不清楚的。这个效果在窍门天下首页右边那里有演示, 
  
{dede:sql sql="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"}<li><a title="[field:title/]" href="[field:array runphp='yes']@me=GetFileUrl(@me['aid'],@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]</a></li>{/dede:sql}
 

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

Pbootcms调用正副标题和摘要字数限制的技巧长度截取使用len=* 或 lencn=* ,使用第二个将避免中英文长... 2022-05-07
织梦源码还原数据后网站打不开解决方案织梦源码还原数据后 首页能打开 内页打不开 这个问题基本是由于没有更新... 2021-09-25
织梦dede标签:arclist标签使用大全arclist是织梦网站建设计系统中重要的标签,同时也是基础的标签... 2021-09-25
织梦友情链接的a标签显示title的方法有哪些?打开 /include/taglib/flink.lib.php 文件... 2021-09-20
dede文章标题字数限制的方法织梦系统默认的文章标题字数限制是60,也就是30个汉字,不够用怎么办?... 2021-09-19
用织梦做中英文网站分页导航和面包屑导航制作方法在英文站中列表分页导航出现首页 上一页 下一页 末页,当前位置:首页a... 2021-09-19
织梦调用指定的多个栏目导航我们在仿站的过程中。经常会遇到需要调用多个指定的栏目导航,那我们如... 2021-09-19
织梦系统教程:删除系统自定义变量的方法有哪些?本文实例讲述了dedecms删除系统自定义变量的方法。分享给大家供大家... 2021-09-17
织梦网站出现多图发布无法使用页面空白的原因昨天小编在使用织梦网站的时候遇到一个问题,在发布文章时,因为是使用了多... 2021-09-17
织梦上传图片弹出提示302的解决办法织梦图片集 上传图片不能上传 弹出提示302这个问题是前两天遇到的,本... 2021-09-17
织梦DedeCMS列表怎样调取文章 body 内的文章在织梦Dedecms体系里挪用文章简介凡是都是行使 [field:de... 2021-07-22
DEDECMS搜索结果按点击排序的简单修改教程DEDE默认的搜索功能,所得到的结果是按照文章加入的先后排序的 很多时... 2021-07-22
织梦模板里面获取当前页面的路径的方法织梦cms模板自带的一个全局函数,我们可以用标签的形式将它在前台调用出... 2021-07-22
织梦模板DEDECMS修改下载地址{dede:field name='softlinks'/}格式织梦DEDECMS修改下载地址{dede:field name=sof... 2021-07-22
织梦去掉{dede:field.body/} 中的p元素我们在后台添加内容的时候,系统往往会自动增加P/P元素,特别是有些时候... 2021-07-27
织梦会员中心获取登录用户名与ID号的方法本文实例讲述了Dedecms获取登录用户名与ID号的方法。分享给大家供... 2021-07-22
织梦搜索结果增加dede:tag标签支持在织梦的搜索结果页面中,如果要使用dede:tag等标签的支持,你需要... 2021-07-22
织梦首页调用随机文章定时自动更新,提高收录速度及权重相信做过SEO的站长朋友都知道网站首页内容的更新频率直接决定了网站的收... 2021-07-22
DedeCMS将data目录迁移到web根目录之外DedeCMS是不仅是中国站长使用量大,也是企业用户使用大的PHP... 2021-07-22
织梦图集软件模型后台关键词输入英文逗号“,”不见了图片集与软件的文章编辑无法输入英文逗号,,包括关键词也无法用英文逗号隔... 2021-07-27
DedeTag Engine Create File False的原因及解决办法版本:DEDE所有版本,DEDE_v5,V5.3,V5.5 原因:要创... 2021-07-27
织梦会员中心模板调用某个栏目名和栏目下文档的办法大家在用到 dedecms 织梦模板 时候,需要在会员中心模板调用栏目... 2021-07-22
织梦在高环境PHP5.4版本上存在的后台系统设置空白问题织梦DEDECMS5.7在高环境PHP5.4版本上存在的问题全面解决方... 2021-07-22

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