迁移MySQL数据库版本5.6到5.5(Django)结构转储导入失败

时间:2016-10-21 09:10:25

标签: mysql django cleardb

当地我正在使用MySQL 5.6版开发Django项目 我试图在Azure上托管数据库,不幸的是ClearDB支持5.5而不是5.6。

我正在使用MySQL Workbench上的导出/导入功能迁移数据。

我首先转储数据库的结构,但语法失败并不确定原因。

02:09:05 Restoring C:\Users\Saher\Documents\dumps\Dumpauthmodels.sql
Running: mysql.exe --defaults-file="c:\users\saher\appdata\local\temp\tmpb3d1gg.cnf"  --protocol=tcp --host=us-cdbr-azure-west-b.cleardb.com --user=b42d1da1703a84 --port=3306 --default-character-set=utf8 --comments --database=mytravelsdb < "C:\\Users\\Saher\\Documents\\dumps\\Dumpauthmodels.sql"
ERROR 1064 (42000) at line 79: 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),
  `is_superuser` tinyint(1) NOT NULL,
  `username` varchar(30) COLLATE utf8' at line 4

Operation failed with exitcode 1
02:09:07 Import of C:\Users\Saher\Documents\dumps\Dumpauthmodels.sql has finished with 1 errors

这只是Django表模型的一部分。

我知道我可以简单地忽略这些表,只使用Django migrata / syncdb命令重新创建,但我很好奇在5.5和5.6之间创建表格语法会导致语法错误。

以下是来自localhost MySQL 5.6的转储中的表结构

--
-- 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) COLLATE utf8_unicode_ci NOT NULL,
  `last_login` datetime(6),
  `is_superuser` tinyint(1) NOT NULL,
  `username` varchar(30) COLLATE utf8_unicode_ci NOT NULL,
  `first_name` varchar(30) COLLATE utf8_unicode_ci NOT NULL,
  `last_name` varchar(30) COLLATE utf8_unicode_ci NOT NULL,
  `email` varchar(254) COLLATE utf8_unicode_ci,
  `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 COLLATE=utf8_unicode_ci;
/*!40101 SET character_set_client = @saved_cs_client */;

1 个答案:

答案 0 :(得分:0)

错误消息是欺骗我必须在编辑器中发布查询以查看错误。似乎MySQL 5.6具有TIMESTAMP和DATETIME的自动初始化和更新,如果您使用这样的语法,则支持该

CREATE TABLE t1 (
  ts TIMESTAMP(6) DEFAULT CURRENT_TIMESTAMP(6) ON UPDATE CURRENT_TIMESTAMP(6)
);

这在5.5中不受支持,因此需要在每个日期时间和时间戳之后删除括号。

导入现在有效。