将架构备份从 MySQL 5.6 恢复到 5.5
Restoring schema backup from MySQL 5.6 to 5.5
我一直在使用 MySQL 5.6 开发应用程序,现在我必须将它安装在使用 MySQL 5.5 的生产服务器上。问题是通过 mysqldump 生成的备份似乎不向后兼容。
因为我无法在任何机器上更改 MySQL 版本。我正在寻找一种向后兼容 5.5 的数据导出方式,或者一种从 5.6 导入数据的方式。
我遇到的错误是:
ERROR 1064 (42000) at line 105: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '(6) DEFAULT NULL,
is_superuser
tinyint(1) NOT NULL,
username
varchar(30)' at line 4
有问题的代码是:
--
-- Table structure for table `auth_user`
--
DROP TABLE IF EXISTS `auth_user`;
/*!40101 SET @saved_cs_client = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `auth_user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`password` varchar(128) NOT NULL,
`last_login` datetime(6) DEFAULT NULL,
`is_superuser` tinyint(1) NOT NULL,
`username` varchar(30) NOT NULL,
`first_name` varchar(30) NOT NULL,
`last_name` varchar(30) NOT NULL,
`email` varchar(254) NOT NULL,
`is_staff` tinyint(1) NOT NULL,
`is_active` tinyint(1) NOT NULL,
`date_joined` datetime(6) NOT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `username` (`username`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;
/*!40101 SET character_set_client = @saved_cs_client */;
问题好像是datetime(6)
,MySQL5.5
不接受
我最终将备份文件中出现的所有 datetime(6)
替换为 datetime
。
目前一切正常。
我一直在使用 MySQL 5.6 开发应用程序,现在我必须将它安装在使用 MySQL 5.5 的生产服务器上。问题是通过 mysqldump 生成的备份似乎不向后兼容。
因为我无法在任何机器上更改 MySQL 版本。我正在寻找一种向后兼容 5.5 的数据导出方式,或者一种从 5.6 导入数据的方式。
我遇到的错误是:
ERROR 1064 (42000) at line 105: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '(6) DEFAULT NULL,
is_superuser
tinyint(1) NOT NULL,username
varchar(30)' at line 4
有问题的代码是:
--
-- Table structure for table `auth_user`
--
DROP TABLE IF EXISTS `auth_user`;
/*!40101 SET @saved_cs_client = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `auth_user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`password` varchar(128) NOT NULL,
`last_login` datetime(6) DEFAULT NULL,
`is_superuser` tinyint(1) NOT NULL,
`username` varchar(30) NOT NULL,
`first_name` varchar(30) NOT NULL,
`last_name` varchar(30) NOT NULL,
`email` varchar(254) NOT NULL,
`is_staff` tinyint(1) NOT NULL,
`is_active` tinyint(1) NOT NULL,
`date_joined` datetime(6) NOT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `username` (`username`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;
/*!40101 SET character_set_client = @saved_cs_client */;
问题好像是datetime(6)
,MySQL5.5
我最终将备份文件中出现的所有 datetime(6)
替换为 datetime
。
目前一切正常。