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代码
程序代码
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;
然后再次打开,问题解决
新闻热点
疑难解答