首页 > 网站 > 建站经验 > 正文

解决ecshop搬家恢复出现ecs_sessions问题

2024-04-25 20:40:57
字体:
来源:转载
供稿:网友

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;

然后再次打开,问题解决

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表