Сбой импорта структурного дампа базы данных MySQL версии 5.6 на 5.5 (Django)

#mysql #django #cleardb

#mysql #django #cleardb

Вопрос:

Локально я работал над проектом Django с MySQL версии 5.6, я пытаюсь разместить базу данных в Azure и, к сожалению, ClearDB поддерживает 5.5, а не 5.6.

Я переношу данные, используя функциональность экспорта / импорта в MySQL Workbench.

Сначала я сбрасываю структуру базы данных, и это приводит к сбою в синтаксисе, не уверен, почему.

 02:09:05 Restoring C:UsersSaherDocumentsdumpsDumpauthmodels.sql
Running: mysql.exe --defaults-file="c:userssaherappdatalocaltemptmpb3d1gg.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:UsersSaherDocumentsdumpsDumpauthmodels.sql has finished with 1 errors
  

Это просто часть табличной модели Django.

Я знаю, что могу просто проигнорировать эти таблицы и просто воссоздать их с помощью команд Django migrata / syncdb, но мне любопытно, какой синтаксис Create table изменился между 5.5 и 5.6, вызвав синтаксическую ошибку.

Вот структура таблицы в дампе с локального хостинга 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:

Сообщение об ошибке обманчиво, мне пришлось опубликовать запрос в редакторе, чтобы просмотреть ошибку. Похоже, что MySQL 5.6 имеет автоматическую инициализацию и обновление для временных меток и DATETIME, которые поддерживаются, если вы используете такой синтаксис

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

Это не поддерживается в версии 5.5, поэтому нужно избавиться от круглых скобок после каждой даты-времени и временной метки.

Теперь импорт сработал.