Привет! Подскажите как правильно экспортировать\импортировать тип данных point Вот таблица mysql

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

Как с этим бороться?

16 ответов

74 просмотра
Иван- Автор вопроса

а как дамп такой сделать? )

Иван
а как дамп такой сделать? )

насколько я вижу у 8 версии с дампом таких данных проблем быть не должно при использовании --hex-blob

Иван- Автор вопроса
Vitaly Larin
насколько я вижу у 8 версии с дампом таких данных ...

ну я эе скинул пример дампа с опцией этой выше

Иван- Автор вопроса

даже если я напишу скрипт, который исправит '0x000000000101000000083DEFBFBD55EFBFBD7F5040EFBFBDEFBFBDEFBFBD4BEFBFBD4C40' в ST_GeomFromWKB(X'000000000101000000083DEFBFBD55EFBFBD7F5040EFBFBDEFBFBDEFBFBD4BEFBFBD4C40') то это не поможет так как хешь генерируется не для этой функции ST_GeomFromWKB Error in query (3037): Invalid GIS data provided to function st_geomfromwkb.

Иван
даже если я напишу скрипт, который исправит '0x000...

ваша проблема похожа на баг https://bugs.mysql.com/bug.php?id=43544

Вот тут в чём ошибка ?

Иван- Автор вопроса
Ilya Zviagin
Вот тут в чём ошибка ?

Error in query (1416): Cannot get geometry object from data you send to the GEOMETRY field

Иван
Error in query (1416): Cannot get geometry object ...

Ну твоя ошибка в том, что ты дамп из Марии загружаешь в ванильный 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 и дампить уже его. Заморочно, но работать будет

Иван- Автор вопроса
Ilya Zviagin
Вроде как смотрю по доке, и --hex-blog не должно в...

я пробовал без —hex-blob вот такое отдает '\0\0\0\0 \0\0\0 =�U�P@���K�L@' попробую через view, спасибо!

Иван
я пробовал без —hex-blob вот такое отдает '\0\0\0\...

А с чего вообще идея переносить БД именно в MySQL ?

Ну это плохо, потому что оно может не будет работать, а отвечать - тебе

Иван- Автор вопроса
Ilya Zviagin
Ну это плохо, потому что оно может не будет работа...

я пока просто смотрю на локалке что может пойти не так ) спасибо за предупреждение

Похожие вопросы

Обсуждают сегодня

Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Объясните, пожалуйста, почему компилятор ругается на использование в условии неинициализированной переменной: int x; Task.Run(async () => { x = await somefunc(); }).Wait...
Александр
5
Ребят, подскажите, пожалуйста, почему в префиксе к ассетам, которые генерируются через фильтр | theme в шаблоне, стал вдруг появляться index.php? Вот так выглядит ссылка на а...
Виталий
1
Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
Блин, ребята, сори за тупые вопросы. А можно ли как-то открыть вебапку по нажатию на кнопку в меню(которое появляется слева, команды)?
Artem Stormageddon
3
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
13
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
Коллеги, может знает кто, можно ли цвет бейджа счётчика в BackendMenu менять без бубнов?
Alex Blaze
3
Карта сайта