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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Insert into table данных из ResultSet, Помогите советом есть ли готовые решения 
V
    Опции темы
SherbAnt
Дата 25.1.2011, 13:08 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Добрый день, уважаемые.

Такая ситуация. Есть 2 базы данных от разных производителей (Teradata[1] и Derby[2]).
Нужно выполнить select запрос к первой и создать таблицу с результатом во второй. Создание таблицы я уже сделал на основе мета-информации из ResultSet. А вот с insert'ом беда. Очень многие нюансы этих двух БД не сходятся. Приходится делать кучу костылей что бы построить валидный запрос.

Может я выдумываю велосипед? Подскажите, пожалуйста, какое нибудь более менее готовое решение.

Заранее спасибо smile
PM MAIL Skype   Вверх
LSD
Дата 25.1.2011, 14:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


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

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



Цитата(SherbAnt @  25.1.2011,  14:08 Найти цитируемый пост)
Подскажите, пожалуйста, какое нибудь более менее готовое решение.

ORM, например Hibernate.


--------------------
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   Вверх
SherbAnt
Дата 25.1.2011, 14:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Тоже вариант, конечно. Но больно "дорогой". Вторая база по возможности должна быть embedded.  Что бы пользователь вообще не заморачивался с ее установкой и настройкой.
Похоже придется писать свой конвертор типов и значений
PM MAIL Skype   Вверх
LSD
Дата 25.1.2011, 14:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


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

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



Цитата(SherbAnt @  25.1.2011,  15:51 Найти цитируемый пост)
Тоже вариант, конечно. Но больно "дорогой".

Тут уж сами решайте, что вам дороже - время разработчика или пара мегабайт, на библиотеки.


--------------------
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   Вверх
Temdegon
Дата 25.1.2011, 16:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

Репутация: 7
Всего: 9



Цитата

Вторая база по возможности должна быть embedded.  Что бы пользователь вообще не заморачивался с ее установкой и настройкой.

Ну это не мешает использовать Hibernate. 
А вообще, какая может быть беда с Insert? Какие там костыли? Можете подробнее описать? По мне так prepareStatement и вперед.
PM MAIL   Вверх
SherbAnt
Дата 26.1.2011, 18:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Костыли есть. Ну например у этих баз разный формат хранения Timestamp. Решил проблему переформатированием строки в нужный формат. Далее DerbyDB не знает про такой тип данных как TINYINT. Пришлось вставить проверку типа и возвращать INTEGER. Когда наткнулся на третье несовпадение, сработал внутренний сигнал тревоги. Понял что код обрастает костылями, и решил спросить у знающих людей smile
Hibernate использовать нельзя, так как ResultSet ко мне приходит снаружи. Я его перехватываю.

В общем, написал свой wrapper который оборачивает Type/Value входящего ResultSet'а. Хотя бы размести все костыли в одном месте. Всем спасибо за советы.
Тему я помечу как решенную, но если появятся мысли - welcome! С удовольствием перепишу этот ужас по фэншую  smile 

Это сообщение отредактировал(а) SherbAnt - 26.1.2011, 18:58
PM MAIL Skype   Вверх
Temdegon
Дата 27.1.2011, 00:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

Репутация: 7
Всего: 9



Я чего-то не понимаю, по этому и хочу разобраться, т.сказать на будущее.
Цитата

Ну например у этих баз разный формат хранения Timestamp. 

Не врубаюсь, причем здесь формат хранения. Это проблема базы данных и JDBC. Я подозреваю, вы используете
ResultSet
У него есть метод
Код

Timestamp getTimestamp(int columnIndex) 

А PreparedStatement есть метод
Код

void setTimestamp(int parameterIndex, Timestamp x) 

Какие строки? Какие форматы хранения?
Или вы SQL вместе с значениями в строку собираете?
То же самое и с TINYINT. Определилсь, что будете использовать вместо него INTEGER, ну так и делайте getInt, SetInt. 
Я с JDBC мало работал, но мне казалось что там все просто. Сейчас вот закрались сомнения, что я чего-то не догоняю  smile 

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


Leprechaun Software Developer
****


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

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



Кстати для вставки можно использовать непосредственно ResultSet.
Код

Statement stmt = connection.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE);
ResultSet resultSet = stmt.executeQuery("SELECT * FROM my_table");
resultSet.moveToInsertRow();
resultSet.updateString("col_string", "new data");
resultSet.insertRow();



--------------------
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   Вверх
SherbAnt
Дата 27.1.2011, 20:36 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Цитата(LSD @  27.1.2011,  20:45 Найти цитируемый пост)
Кстати для вставки можно использовать непосредственно ResultSet.


Спасибо! Вот этого я не знал
PM MAIL Skype   Вверх
Temdegon
Дата 27.1.2011, 20:56 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

Репутация: 7
Всего: 9



Мммда... Мой вопрос че-то игнорят  smile 
PM MAIL   Вверх
SherbAnt
Дата 30.1.2011, 16:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Не игнорю, просто не часто на форум захожу.


Цитата(Temdegon @  27.1.2011,  03:39 Найти цитируемый пост)
Я подозреваю, вы используете
ResultSet
У него есть метод
код Java
1:
Timestamp getTimestamp(int columnIndex) 

А PreparedStatement есть метод
код Java
1:
void setTimestamp(int parameterIndex, Timestamp x) 


Все замечательно, но как же узнать какой из методов PreparedStatement вызывать?
Входящий тип можно получить 
Код

ResulSetMetaData metaData = rs.getMetaData();
String type = metaData.getColumnTypeName(i)


Но в PreparedStatement придется либо вызывать setObject(obj) либо организовывать все тот же wrapper который я уже написал.
PM MAIL Skype   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
javastic
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

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

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


 




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


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

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