dedesql自定义字段_织梦dede:sql根据自定义字段填的文章id获取相关文章

1、后台模型添加自定义字段,数据类型用单行文本(varchar),用来填要调用的相关文章的id

填多个文章id用英文逗号隔开,例如:3,5,6,8,9

2、在内容页模板里写dede:sql标签

{dede:sql sql="SELECT * FROM #@_archives WHERE arcrank>-1 AND id in(~自定义字段名~) ORDER BY FIELD(id,~自定义字段名~)"}

[field:title/]

[field:description/]

{/dede:sql}

~自定义字段名~ 有2处,改成你自己的字段名,例如 ~likeids~

3、打开 /include/taglib/sql.lib.php 找到

preg_match_all("/~([A-Za-z0-9]+)~/s", $sql, $conditions);

改成

preg_match_all("/~([A-Za-z0-9_]+)~/s", $sql, $conditions);

继续找到

$sql = str_replace($conditions[0][$key], "'".addslashes($refObj->Fields[$value])."'", $sql);

改成

if(is_numeric(str_replace(',','',$refObj->Fields[$value])))

{

$sql = str_replace($conditions[0][$key], addslashes($refObj->Fields[$value]), $sql);

}

else

{

$sql = str_replace($conditions[0][$key], "'".addslashes($refObj->Fields[$value])."'", $sql);

}

完成

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值