织梦文章 一编辑显示未生成咋回事
2017-04-13 21:00:17
dedecms
网站的数据库错误了。恢复到之前的数据。然后把缺少的数据插入。生成的时候 发现文章未生成。如何解决这个问题呢 ?
织梦
的文档数据都是存在MySQL数据表里面的,就默认的安装的织梦系统来说,发的文章、软件、图片等等的文档信息,都会储存在dede_archives表中,dede_archives表是文档的主表。织梦是如何来判断一篇文档是否审核或者是否已经生成HTML
文件的呢? 就是通过dede_archives表中的arcrank和ismake两个字段,今天来了解这两个字段的含义,具体来说arcrank是看这篇文章审核没有,它有-1和0两个值;ismake是代表是否生成了静态文件,它有三个值:0,1,-1。 下面是对各种情况进行组合,都有可能出现的文档状态: 审核状态生成html:$arcrank=-1 $ismake = 0 (但是后台文章列表那里显示没有生成,点击修改文章是显示以生成,其实没生成,因为是未审核,一但审核,自动变成1)。 审核状态动态浏览:$arcrank=-1 $ismake = -1 ; 开放状态生成html:$arcrank=0 $ismake = 1 ; 开放状态动态浏览:$arcrank=0 $ismake = -1 ; 总结一下,通过上面四个,得出以下结论: $arcrank =-1是代表未审核,0带表审核: $ismake生成html:0或者1;入库的时候是0,程序会判断是不是生成了html,如果是会调整到1; 另外还有一个需要注意的地方,就是织梦还有一个文档微表dede_arctiny,如果我们在使用SQL语句对文档批量进行审核或者未审核操作时,必须把微表中的arcrank字段也设为相同的值. 网上比较常见的办法是使用SQL语句设置,具体的SQL语句如下: Update dede_archives set arcrank = -1,ismake=0; 使用这两条SQL语句之后,所有的文章文档的状态就变成了未审核了,不过会遇到一个问题,有的是前台动态还可以访问,后台一键生成的时候居然还会生成,只是不会真正的生成文件,产生这种情况的原因是什么呢?其实是织梦DedeCMS的微表和主表的状态没有统一,网上有一种比较死的办法,是把文章删除之后再恢复文章就解决了。 今天要说的还是使用SQL语句解决这个问题,都知道是微表的问题了,只需要使用如下的SQL语句即可解决: Update dede_arctiny set arcrank = -1; 综合一下,我们在把所有的文章设置为未审核状态的时候,一定要使用以下的SQL语句,代码如下: Update dede_archives set arcrank = -1,ismake=0; Update dede_arctiny set arcrank = -1; 这样就把文章的主表、微表等等的信息都同步了. 最后发现是因为dede_archives与dede_arctiny表中有两不统一导致的.
最重要的原因是
dede_arctiny这个表里面没有对应的记录,然后插入问题解决。