本帖最后由 leixuok 于 2019-4-22 11:42 编辑
感谢@crx349同学的回复及QQ上的交流,最终通过对升级程序跟踪后,发现升级程序在某些特殊情况下(尤其曾有过服务器迁移,特别是通过非discuz内部程序进行数据备份和恢复的情况为最典型)存在BUG,并成功解决。
“USING BTREE”,通过非DZ程序导出数据时,会在主键和索引后面加上这个语法,但最新的安装程序的建表脚本里并没有这个语法,导致系统升级时认为主键不一致,所以需要改表名,再重新建表。然鹅,官方升级程序在改表名这种升级方式时,忽略了几个问题!导到升级不成功!
同时,官方升级程序通过改表的方式升级也是存在极大的漏洞:
一、只干了改表的事和新建表的事,改完表后,原来不存在了,但程序里却在对该表(已确认就上上述的两张表)进行查询操作,所以会报“表不存在”的错误,导致升级程序终止,不能继续升级;
二,完成后改表及建表操作后(即便像前面我的操作一样,手动把那两张表建好以后),升级程序并没有将旧表数据写入新表,最终导致没有数据!
解决办法:
确认自己的程序是3.2及以后的版本的情况下,注释掉升级程序改表操作的代码即可(此种办法只是权宜之计,快速处理升级问题)
后续拟通过修改程序,对“USING BTREE”做出判断。就比较完美了!
以上,有对不对的,欢迎指出、纠正。
|