织梦系统dedecms loop的循环标签怎么使用?
DedeCMS v5.7的循环标签非常好用,你可以用它来调用任何表中的数据,我们先来看看循环标签的语法结构。
{dede:loop table='table_name' if='condition' sort='field_name' row='line_number'}
<a href='[field:arcurl/]'>[field:title/]</a><br />
{/dede:loop}
上面就是loop标签的语法了,其中table_name指的是表名,也就是要查询的数据所在的表;condition是条件,相当于SQL语句中的where;field_name指的是排序方式,相当于SQL语句中的order by;line_number是行数,指要查询多少条数据,我们通过两个例子来说明loop标签的强大功能。
{dede:loop table='dede_archives' sort='mid' row='4' if='mid=1'}
<a href='[field:arcurl/]'>[field:title/]</a>([field:mid/])<br />
{/dede:loop}
上面的例子是调用DedeCMS文档主表的文章,根据mid也即会员ID号排序,条件是会员ID等于1。换句话说,这段代码的作用是查询会员ID为1的用户发布的4篇文档。
站长们也许会问为什么loop标签叫调用标签呢?其实它除了调用DedeCMS数据表里面的内容外,还可以调用其他程序数据表中的数据,从而起到整合数据的作用。
{dede:loop table='cdb_threads' if='' sort='tid' row='8'}
<a href="http://www.ithov.net/php-[field:tid/]-1-1.html" rel="external nofollow" >
[field:subject function="cn_substr('@me',40)"/]
</a><br />
{/dede:loop}
上述代码的功能和个例子类似,它用来获取Discuz! 论坛的主题帖子,URL标签中的域名要替换成自己的域名,各位站长可以试验下。
dedecms loop和sql标签多表查询对比
loop多表查询
{dede:loop table='dede_category_brand b,dede_goods g,dede_category_series s' row='8' if='b.cat_id=g.cat_brand_id and g.cat_series_id=s.series_name and g.cat_id=72'}
[field:cat_name/]
[field:series_name/]
[field:goods_model/]
[field:shop_price/]
{/dede:loop}
sql多表查询
{dede:sql sql='select * from dede_category_brand b,dede_goods g,dede_category_series s where b.cat_id=g.cat_brand_id and g.cat_series_id=s.series_name and g.cat_id=71 limit 0,8'}
[field:cat_name/]
[field:series_name/]
[field:goods_model/]
[field:shop_price/]
{/dede:sql}
使用起来非常的方便!