Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Перенос базы данных из Sybase ASA 5.5 MySQL 5, Возможно ли это? 
:(
    Опции темы
Berliner
Дата 6.3.2006, 17:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 803
Регистрация: 18.5.2005

Репутация: нет
Всего: 2



Здраствууйте ! интересно возможен ли перенос данных из Sybase ASA на My SQL 5 Перенести хочу хотябы таблицы. Хранимые процедуры и тригера думаю надо руками переписывать. Насколько это сложно сделать? Может кто-то пытался сделать подобное?

PM   Вверх
chief39
Дата 6.3.2006, 18:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


карманная тигра
***


Профиль
Группа: Участник Клуба
Сообщений: 1631
Регистрация: 20.5.2005
Где: Киев

Репутация: 8
Всего: 77



нуууу..... о софтине такой не слыхал...
Структуру данных создавай ручками...
Ну а перекачивание данных.... наверное придётся аппликуху писать а-ля pump. Качаешь оттеда - льёшь туда. Соблюдая очерёдность чтоб с форэйн киз проблем не было. С айди полями - тут тоже подумать надо. Смотря как они у тебя в АСЕ


--------------------
Люди - это свечи. Они либо горят, либо их - в жопу!(с)

PM MAIL   Вверх
batigoal
Дата 6.3.2006, 19:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Нелетучий Мыш
****


Профиль
Группа: Участник Клуба
Сообщений: 6423
Регистрация: 28.12.2004
Где: Санктъ-Петербургъ

Репутация: 1
Всего: 151



Я полагаю, что должны быть в составе обеих СУБД утилиты, поддерживающие экспорт/импорт данных в XML/plain text. Неужели нету?

Это сообщение отредактировал(а) Lamer George - 6.3.2006, 19:51


--------------------
"Чтобы правильно задать вопрос, нужно знать большую часть ответа" (Р. Шекли)
ЖоржЖЖ
PM WWW   Вверх
LSD
Дата 6.3.2006, 21:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 24
Всего: 538



Вытянуть структуру базы и конвертануть ее, может тот же PowerDesigner.


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
Berliner
Дата 7.3.2006, 11:25 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 803
Регистрация: 18.5.2005

Репутация: нет
Всего: 2



Спасиб, требуется наиболее простой вариант.
PM   Вверх
chief39
Дата 7.3.2006, 12:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


карманная тигра
***


Профиль
Группа: Участник Клуба
Сообщений: 1631
Регистрация: 20.5.2005
Где: Киев

Репутация: 8
Всего: 77



Цитата(LSD @ 6.3.2006, 21:44 Найти цитируемый пост)
Вытянуть структуру базы и конвертануть ее, может тот же PowerDesigner.

А данные? Может там и таблиц-то немного... Их даже ручками создать можно будет.. а вот перекачать.....

Цитата(Lamer George @ 6.3.2006, 19:38 Найти цитируемый пост)
Я полагаю, что должны быть в составе обеих СУБД утилиты, поддерживающие экспорт/импорт данных в XML/plain text. Неужели нету?

В универсальное представление какое-то? Ну то есть, одна СУБД воспримет данные в XML от другой СУБД?



--------------------
Люди - это свечи. Они либо горят, либо их - в жопу!(с)

PM MAIL   Вверх
Berliner
Дата 7.3.2006, 12:35 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 803
Регистрация: 18.5.2005

Репутация: нет
Всего: 2



таблиц очень много
Предложите наиболее легкие варианты
PM   Вверх
LSD
Дата 7.3.2006, 13:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 24
Всего: 538



Цитата(chief39 @ 7.3.2006, 12:28 Найти цитируемый пост)
В универсальное представление какое-то? Ну то есть, одна СУБД воспримет данные в XML от другой СУБД?

Ну например CSV. А вообще надо смотреть утилиты экспорта/импрота в Sybase и MySQL.
Или накатать самому приложение на Java, это не так сложно как кажется smile


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
Berliner
Дата 7.3.2006, 13:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 803
Регистрация: 18.5.2005

Репутация: нет
Всего: 2



Т.Е нужно создать приложение которое сможет считывать данные(Импорт) из одной базы данных и экспортировать в другую базу данных(My SQL)
Напиши пожалуста по шагам(подробнее), что должно єто приложение делать.
PM   Вверх
LSD
Дата 7.3.2006, 13:32 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 24
Всего: 538



1. Соединяемся с обеими базами.
2. Получаем список таблиц в обоих базах (на основе Connection.getMetaData()) и выбираем те которые будем "перекачивать" (по списку таблиц или просто все у которых имена совпадают)
3. Выбираем данные из таблици, формируем insert для другой базы (на основе RowSet.getMetaData()), идем по курсору и вставляем данные в другую базу
4. Повторяем пункт 3 для всех таблиц.


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
chief39
Дата 7.3.2006, 16:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


карманная тигра
***


Профиль
Группа: Участник Клуба
Сообщений: 1631
Регистрация: 20.5.2005
Где: Киев

Репутация: 8
Всего: 77



1. Только не забудь о том порядке таблиц, который позволит вставки при наличии внешних ключей.

То есть вставить все записи в таблицу "группы" надо до того, как начнёшь вставки в таблицу "люди", которая ссылается на "группы".

2. Проконтролируй чтоб не было проблем с айдишками. Если в mysql у тебя будет автоинкрементное поле (или какие там есть?) - то при вставке - надо сиё проконтролировать и обдумать....
Например в твоей базе в "группах" айдишки 3, 5, 8. При переносе, в этом поле автоинкрементно сгенерится 1,2,3 (к примеру). При переносе таблицы "люди" её записи будут ссылаться на группы 3,5,8. Две из которых не обнаружат и ругнутся
Тэк штааа... айдишки надо будет вязать по другому на время переноса...


--------------------
Люди - это свечи. Они либо горят, либо их - в жопу!(с)

PM MAIL   Вверх
LSD
Дата 7.3.2006, 17:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 24
Всего: 538



Цитата(chief39 @ 7.3.2006, 16:11 Найти цитируемый пост)
1. Только не забудь о том порядке таблиц, который позволит вставки при наличии внешних ключей.

Угу согласен. Значит придется заранее составить список таблиц и идти по нему.

А вот со вторым пунктом труба, если MySQL не позволяет явно указать значение для автоинкрементного поля то надо или будет вообще отказаться от автоинкрементов в пользу триггер+последовательность, или делать вставку по хитрому алгоритму с учетом всех foreign key.


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
Berliner
Дата 9.3.2006, 12:00 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 803
Регистрация: 18.5.2005

Репутация: нет
Всего: 2



Цитата

1. Только не забудь о том порядке таблиц, который позволит вставки при наличии внешних ключей.

То есть вставить все записи в таблицу "группы" надо до того, как начнёшь вставки в таблицу "люди", которая ссылается на "группы".


Это можно как то програмно отследить без анализа данных "вручную".
База данных большая. По каким признакам это можно отследить. Пример начсет людей и груп я понял. А что скажу люди которые знают хорошо MY SQL ?

PM   Вверх
chief39
Дата 9.3.2006, 12:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


карманная тигра
***


Профиль
Группа: Участник Клуба
Сообщений: 1631
Регистрация: 20.5.2005
Где: Киев

Репутация: 8
Всего: 77



Цитата(Berliner @ 9.3.2006, 12:00 Найти цитируемый пост)
Это можно как то програмно отследить без анализа данных "вручную".

Можно. Не помню как в ASA, но сдаётся мне, не хуже чем в ASE:
Есть табличка sysobjects(там все таблицы, вьюхи, процедуры и многая прочая - юзерские таблицы имеют TYPE="U"), ещё, кажется sysreferences и проч. Вобщем погляди все таблицы на sys. Из них можно вытянуть все связки таблиц и их структуру.
Потом надо построить граф(программно) и начать с тех таблиц, которые ни на что не завязаны и далее спускаться, по мере их переноса, до тех, которые от них зависят. А вот в целевой базе(mysql) придётся отказаться от автоинкрементов.
Или не отказываться, но продумать контроль при переносе.
Например, при переносе "групп" в мускле они создаются с другими айдишками.
при переносе "людей" нужна будет реальная айдишка нужной группы. Надо будет брать айдишку группы в ASA, резолвить в айдишку группы в мускле и вставлять запись о человеке с уже корректной айдишкой группы. Но тогда тебе нужен реальный механизм определения идентификации айдишки по другим аттрибутам (что не предполагается по идее структурой базы и может лишь иногда быть возможно). Или переносить по одной записи и связку "новая айдишка" - "старая айдишка" хранить в памяти, пока она нужна.
Т.е. Взял группу с айди 6, перенёс, в мускле вышло - 3, запомнил связку "6-3".
Потом, когда переносишь "людей", берёшь "человека", если у него - 6, заменешь на 3 и инсертишь в мускль.
Проблема может быть в том, что "люди" у тебя ссылаются на 10 таблиц. Тогда надо все десять таблиц перенести и запомнить для каждой их записи такие резолвы. А потом уже "людей переносить".
Если записей до черта и джвм сдохнет столько в памяти держать - тогда сделай временную табличку в одной из баз - <имя таблицы> <старая айди> <новая айди>. И там храни все данные спокойно до конца переноса.
Так будет логичней всего. Но перед этим всем надо полностью выстроить граф связей и точно обходить его, чётко соблюдая все зависимости.


--------------------
Люди - это свечи. Они либо горят, либо их - в жопу!(с)

PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | СУБД, общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1247 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.