DedeCMS频道内容模型自定义与SQL标签应用

DedeCMS也提供频道内容模型自定义功能,可以根据自己的需求建立频道模型,类似KingCMS的自定义模块。这篇文章不写如何建立频道内容模型,写写在首页或非自定义频道内容列表页如果

 DedeCMS也提供频道内容模型自定义功能,可以根据自己的需求建立频道模型,类似KingCMS的自定义模块。这篇文章不写如何建立频道内容模型,写写在首页或非自定义频道内容列表页如果要调用里面的内容使用的SQL标签。

  要使用SQL标签,最基本的查看数据库字段是一定要会的,特别是如果用自定义模型字段都是自己加的,不是系统默认的。

  先看下面这段调用的语句,我一行行解释吧,这样可能比较好理解。

{dede:sql sql=" SELECT dede_addonevents.aid,dede_addonevents.typeid,dede_addonevents.events_place,dede_addonevents.begin_date,dede_addonevents.end_date, dede_events.ID,dede_events.typeid,dede_events.title,dede_events.description, dede_full_search.aid,dede_full_search.typeid,dede_full_search.url FROM dede_addonevents , dede_events , dede_full_search WHERE dede_addonevents.aid=dede_events.ID AND dede_events.ID=dede_full_search.aid ORDER BY dede_addonevents.aid DESC LIMIT 0, 4 "}[field:events_place/][field:title function="cn_substr(@me,38)"/] [field:description function="cn_substr(@me,38)"/][field:begin_date/]-[field:end_date /]{/dede:sql}


  dede_addonevents 和 dede_events 是自定义生成频道之后自动生成的表,默认的系统中是没有的。dede_full_search 这个表是存储DedeCMS中所有文章或自定义频道文章内容的路径的表,这里要调用URL,一定是需要打开的。

dede_addonevents.aid,dede_addonevents.typeid,dede_addonevents.events_place,dede_addonevents.begin_date,dede_addonevents.end_date,dede_events.ID,dede_events.typeid,dede_events.title,dede_events.description,


  这几个都是自定义表中需要调取的字段,在自定义频道生成的时候DedeCMS系统会自动加上.aid,.ID,.typeid,这样的ID字段,以实现多表关联查询。

  这部分FROM dede_addonevents , dede_events , dede_full_search就不详细解释了,就是调用的表名。

  下面这个部分就是多表关联查询的条件语句了

WHERE dede_addonevents.aid=dede_events.ID 
AND dede_events.ID=dede_full_search.aid


  当然是要ID能匹配上调用的内容才不出错。

ORDER BY dede_addonevents.aid DESC LIMIT 0,4


  这句就是数据显示的倒序正序了,Mysql支持LIMIT 0, 4 这个设置起始位置非常方便。

[field:events_place/][field:title function="cn_substr(@me,38)"/] [field:description function="cn_substr(@me,38)"/][field:begin_date/]-[field:end_date /]


  这个部分就是DedeCMS的标签了,自定义的时候会有字段名,跟系统默认标签基本相近,方法也一致。标签问题查看系统的帮助就可以。

  从这个语句可以看出,如果对DedeCMS的数据库表和字段了解的够清楚基本可以实现想调用什么数据就调用什么数据。以后有时间再看看可以不可以实现多个SQL查询。


本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

dedecms织梦默认的TAG标签不是很灵活。有时候我们的标签需要进行一个分类,能不能像{dede:arclist}标签的自定义属性(如:flag=c,h),这样全站调用的时候更灵活。 全站调用TAG标签方法一般是: {dede:tag row='100' sort='new' getall='1'}a target="_blank
未审核文档的TAG会显示在TAG列表页面, 固然点击进入TAG时, 相关的未审核文章不会显示出来, 这样对用户体验是很不好的. DEDECMS暂时没有提供这个功能,所以要解决这个问题, 让DEDECMS不显示未审核文档的TAG, 就要修改TAG的显示库文件 tag.lib.php。 方法一 打
我们都知道DEDECMS生成的文件夹是按天生成的,只要传了图片就会自动建立个年月日的文件,centos系统下,都是随便排序的,很难找到对应文件夹,如果要按顺序排列,要怎么操作呢? 一、文件管理器: 修改 /dede/templets/file_manage_main.html $dh = dir($inp
我们在用到织梦dedecms软件模型的时候,手动指定地址通常只能是引用其他网址或者链接,我们要实现直接选取站内的文件,这个要怎么操作呢?下面小编一步步为您解答,最终效果如下图所示: 实现教程 1、打开 /dede/templets/soft_add.htm 找到 input type=text
我们有时候需要对织梦文档的点击量进行批量维护,比如采集来的文章,点击量都为0,需要批量修改,可以用到如下方法1。 1、在数据库里运行下面的代码就可以了,文章的点击量变得随机从500到1000 UPDATE dede_archives SET click=FLOOR(500 + (RAND() * 1000))
用过dedecms的朋友都知道,织梦cms后台系统基本参数里是无法直接上传图片的,我们更换logo图只能到ftp里替换,非常的不方便,我们如果想直接在系统基本参数里上传,要怎么处理呢?在这里需要对代码进行修改,具体流程如下: 实现方法,打开/dede/templets/sy