ECshop网店程序在搬迁空间或恢复备份或更换域名出现

MySQL server error report:Array ( [0] => Array ( [message] => MySQL Query Error ) [1] => Array ( [sql] => Insert INTO `test`.`ecs_sessions` (sesskey, expiry, ip, data) VALUES (‘8a3107988bf98cc9a5079fdfbe766120’, ‘1278128679’, ‘127.0.0.1’, ‘a:0:{}’) ) [2] => Array ( [error] => Table ‘test.ecs_sessions’ doesn’t exist ) [3] => Array ( [errno] => 1146 ) )

这是因为备份时少了两个表。
 
解决方法如下:
 
1.关闭网站(防止新的访问更新数据库造成数据不完整)
 
2.进入ecshop后台备份数据库(备份前可以先清理下数据库中的碎片,然后选择完全备份)
 
3.下载整站数据(可以用主机上带的rar打包解压功能将整站打包,这样下载比较快)
 
4.上传整站数据到新空间(尽量保证新空间的php与mysql版本与原空间相同,考虑兼容性,特别是数据库的兼容性。如果上传的是整站压缩包,需要主机支持rar解压),期间的域名的DNS解析等修改跳过
 
5.接下来是恢复数据库,可以采用2个方法
 
a.上传ecshop的安装程序,默认安装后进入后来进行恢复操作
 
b.用主机上的phpmyadmin进行恢复操作(如果数据比较多,sql文件比较多,这个比较麻烦的)
 
6.恢复完成后打开网站,发现出错:出错关键字 sesskey 1146
 
查看了现在的数据库与原来数据库表的差别,发现少了两个表(默认前缀)
 
ecs_sessions 跟 ecs_sessions_data
 
建立它们(只能用phpmyadmin)
 
执行如下SQL代码:

阿里云-推广AD

Create TABLE `ecs_sessions` (  
  `sesskey` varchar(32) binary NOT NULL default ”,  
  `expiry` int(10) unsigned NOT NULL default ‘0’,  
  `userid` mediumint(8) unsigned NOT NULL default ‘0’,  
  `adminid` mediumint(8) unsigned NOT NULL default ‘0’,  
  `ip` varchar(15) NOT NULL default ”,  
  `user_name` varchar(60) NOT NULL default ”,  
  `user_rank` tinyint(3) NOT NULL default ‘0’,  
  `discount` decimal(3,2) NOT NULL default ‘0.00’,  
  `email` varchar(60) NOT NULL default ”,  
  `data` varchar(255) NOT NULL default ”,  
  PRIMARY KEY  (`sesskey`),  
  KEY `expiry` (`expiry`)  
) TYPE=HEAP;  
  
Create TABLE `ecs_sessions_data` (  
  `sesskey` varchar(32) binary NOT NULL default ”,  
  `expiry` int(10) unsigned NOT NULL default ‘0’,  
  `data` longtext NOT NULL,  
  PRIMARY KEY  (`sesskey`),  
  KEY `expiry` (`expiry`)  
) TYPE=MyISAM;   

 
 然后再次打开网站,问题应该可以解决了。