首先我们先来查看 update.php 文件中处理附件部分代码

  1. elseif($_GET['op'] == 'forumattach') {
  2.                 $nextop = 'moderate';
  3.                 $limit = 10000;
  4.                 $start = !empty($_GET['start']) ? $_GET['start'] : 0;
  5.                $needupgrade = DB::query("SELECT COUNT(*) FROM ".DB::table('forum_attachmentfield'), 'SILENT');
  6.                 $count = DB::result_first("SELECT COUNT(*) FROM ".DB::table('forum_attachment'));
  7.                 if($needupgrade && $count) {
  8.                         if(!$start) {
  9.                                 for($i = 0;$i < 10;$i++) {
  10.                                         DB::query("TRUNCATE ".DB::table('forum_attachment_'.$i));
  11.                                 }
  12.                         }
  13.                         $query = DB::query("SELECT a.*,af.description FROM ".DB::table('forum_attachment')." a
  14.                                 LEFT JOIN ".DB::table('forum_attachmentfield')." af USING(aid)
  15.                                 ORDER BY aid LIMIT $start, $limit");
  16.                         if(DB::num_rows($query)) {
  17.            省略。。。。。。。

$needupgrade = DB::query("SELECT COUNT(*) FROM ".DB::table('forum_attachmentfield'), 'SILENT');
代码红色部分,有对 forum_attachmentfield 进行处理,因为这个升级程序是兼容 Discuz! X 系列的升级。如果你升级到 X2 的时候此表还存在,升级到 Discuz! X2.5 就会将附件表 forum_attachment_0 到 9 这些表给处理掉。正常情况 Discuz! X2 升级到 Discuz!   X2.5 是不用处理附件表。 所以,升级到 X2.5 附件为 问号的用户,可以直接导入 X2 备份的数据将附件表 forum_attachment 和  forum_attachment_0 到 9 表 、 forum_attachment_unused 表的数据直接导入

X2.5 的附件表 有对 forum_attachment_type 更改 、添加 了 forum_attachment_exifi 表,导入 X2 的数据之后 请确保这些表都存在