Ver 15.1 Distrib 10.7.4-MariaDB, for Linux (x86_64) using readline 5.1
CREATE TABLE `city` (
`id` int(11) NOT NULL,
`city_name` varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL,
`region_name` varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL,
`country_iso` varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL,
`latlng` point NOT NULL,
PRIMARY KEY (`id`),
KEY `city_name_idx` (`city_name`),
SPATIAL KEY `sp_index` (`latlng`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
экспортирую командой mysqldump с ключом --hex-blob на выходе получаю такой результат
INSERT INTO `city` VALUES
(5,'Усинск','Коми респ.','RUS',0x000000000101000000083DEFBFBD55EFBFBD7F5040EFBFBDEFBFBDEFBFBD4BEFBFBD4C40);
Экспортирую в mysql Ver 8.0.34 for Linux on x86_64 (MySQL Community Server - GPL)
получаю ошибку
Error in query (1416): Cannot get geometry object from data you send to the GEOMETRY field
Как с этим бороться?
а как дамп такой сделать? )
насколько я вижу у 8 версии с дампом таких данных проблем быть не должно при использовании --hex-blob
ну я эе скинул пример дампа с опцией этой выше
даже если я напишу скрипт, который исправит '0x000000000101000000083DEFBFBD55EFBFBD7F5040EFBFBDEFBFBDEFBFBD4BEFBFBD4C40' в ST_GeomFromWKB(X'000000000101000000083DEFBFBD55EFBFBD7F5040EFBFBDEFBFBDEFBFBD4BEFBFBD4C40') то это не поможет так как хешь генерируется не для этой функции ST_GeomFromWKB Error in query (3037): Invalid GIS data provided to function st_geomfromwkb.
ваша проблема похожа на баг https://bugs.mysql.com/bug.php?id=43544
Вот тут в чём ошибка ?
Error in query (1416): Cannot get geometry object from data you send to the GEOMETRY field
Ну твоя ошибка в том, что ты дамп из Марии загружаешь в ванильный MySQL - это родственные, но всё же разные СУБД.
Можешь подсказать пути решения?)
Тебе надо 0) проверить, что MySQL 8 поддерживает те же самые типы POINT . что и Мария 1) выгрузить из Марии данные POINT в виде WKT https://mariadb.com/kb/en/wkt/ 2) загрузить в MySQL данные POINT в виде WKT - https://dev.mysql.com/doc/refman/8.0/en/gis-data-formats.html#gis-wkt-format
Вроде как смотрю по доке, и --hex-blog не должно влиять на Spatial data types Попробуй убери его и сделай пробный дамп. Если не будет WKT , то не знаю как ещё делать. По документации, похоже, Spatial data не поддерживаются maria-dump-ом. Тогда можно сделать view на каждую таблицу с Spatial data и в нём каждое поле с POINT преобразовать в WKT и дампить уже его. Заморочно, но работать будет
я пробовал без —hex-blob вот такое отдает '\0\0\0\0 \0\0\0 =�U�P@���K�L@' попробую через view, спасибо!
А с чего вообще идея переносить БД именно в MySQL ?
Ну это плохо, потому что оно может не будет работать, а отвечать - тебе
я пока просто смотрю на локалке что может пойти не так ) спасибо за предупреждение
Обсуждают сегодня