dedecms5.1升级为5.3导致tag丢失怎么办?
dedecms5.1升级为5.3导致tag丢失等问题处理
已经可以正常现实文章页面的 tag 带链接哦,而且升级前文章的tag 都已经恢复了。下面是具体的解决方法。主要是最后的那句sql执行以下即可。
推荐学习:织梦cms
其实修复tag问题的回答论坛上很多人都已经回答过了,可能是大家都没有认真的去尝试,并不是人家提供的代码不对
而是你不能完全的copy人家的代码,很多代码要修改数据表前缀才能使用。
下面介绍一下我解决tag 问题的方法:
首先是在文章页面调用当前文章的tag代码:
直接用tag: {dede:field.tags/} 替换原来的代码
比如说我网站以前获得当前文章tag代码是这样的注意红色部分是代码,黑色你自己随便:
tag :{dede:tag type='current'/}
所以现在的显示tag地方的原代码是:
tag: {dede:field.tags/}
上面是第一部,下面要修改dede cms 的相关文件了,打开\include\common.func.php这个文件
找到 //获得某文档的所有tag 这一部分,把下面的这些代码
代码如下:
function gettags($aid) { global $dsql; $tags = ''; $query = "select tag from [url=mailto:`ddmx_taglist]`ddmx_taglist[/url]` where aid='$aid' "; $dsql->execute('tag',$query); while($row = $dsql->getarray('tag')) { $tags .= ($tags=='' ? $row['tag'] : ','.$row['tag']); } return $tags; } function paramerror() { showmsg('对不起,你输入的参数有误!','javascript:;'); exit(); }
替换成为下面的这些代码,期间要根据自己的实际情况修改自己的表前缀。
注意下面的那个'dede_dedecmstaglist',根据自己的表前缀修改一下吧。
代码如下:
function gettags($aid) { global $dsql; $tags = ''; $query = "select tag from `dede_dedecmstaglist` where aid='$aid' "; $dsql->execute('tag',$query); while($row = $dsql->getarray('tag')) { $tags .= ($tags=='' ? "<a href=/tags.php?/{$row['tag']} target=_blank>{$row['tag']}</a>" : ','."<a href=/tags.php?/{$row['tag']} target=_blank>{$row['tag']}</a>"); } return $tags; } function paramerror() { showmsg('对不起,你输入的参数有误!','javascript:;'); exit(); }
ok,现在只要你的文章的tag没有丢失的话,完成上面的步骤就可以在文章页调用带链接的文章tag了。
如果你的tag在升级过程中丢失的话,那么执行下面的步骤吧。
进入你的网站管理后台
选择“系统”----------“sql命令行工具”
运行sql命令:
代码如下:
update dede_tagindex,dede_taglist set dede_taglist.tag = dede_tagindex.tag where dede_taglist.tid=dede_tagindex.id;
注意不要完全copy上面的代码哦,更加自己的实际情况修改表前缀.
以上就是dedecms5.1升级为5.3导致tag丢失怎么办的详细内容。