原文来自:https://www.zixuephp.com
织梦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语句,代码如下:
- Updatedede_archivessetarcrank=-1,ismake=0;//www.phpfensi.com
- Updatedede_arctinysetarcrank=-1;
这样就把文章的主表、微表等等的信息都同步了.
最后发现是因为dede_archives与dede_arctiny表中有两不统一导致的.