本文主要是介绍DedeCMS_如何使sql标签的sql属性能引用其他变量值?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
一般在文章页使用sql标签匹配另外一个参数,我们会按照以下这样写,但结果输出为空:
原因:include/taglib/sql.lib.php 传递变量时,会自动带上 ‘ 单引号 例如 LIKE '%~'title'~%' 而不是 LIKE '%~title~%'
// 根据文章页标题(title变量值)来过滤文章
<pre name="code" class="php">{dede:sql sql="SELECT id,title,description,litpic FROM dede_archives WHERE shorttitle LIKE '%~title~%'"}<li><a href='/plus/view.php?aid=[field:id/]'>[field:title/]</a> </li> {/dede:sql}
这时,dedecms模板标签默认编译的结果就是SELECT id,title,description,litpic FROM dede_archives WHERE shorttitle LIKE '%~title~%',并没有把当前文章页title变量值传递进来进行过滤。
为实现能传递变量值,我们需要对织梦cms的函数进行以下修改:
$sql = str_replace($conditions[0][$key], "'".addslashes($refObj->Fields[$value])."'", $sql);
修改为(只需把引号去掉就可以实现):
$sql = str_replace($conditions[0][$key], addslashes($refObj->Fields[$value]), $sql);
如果您不想直接修改sql标签,以防之前的sql标签使用受影响,可以复制一份include/taglib/sql.lib.php重命名为likesql.lib.php并将对应代码(如函数名lib_sql,改为lib_likesql)修改,这样我们可以不影响{dede:sql sql=""}标签而用新的{dede:likesql sql=""}来实现模糊搜索。
这篇关于DedeCMS_如何使sql标签的sql属性能引用其他变量值?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!