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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Резервное копирование БД на DB2 
V
    Опции темы
Zhenyusya
  Дата 9.10.2008, 04:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Задача: реализовать резервное копирование БД на DB2.
В Центре управления DB2 это делается простым запросом:
Код

CONNECT TO JOURNAL;
QUIESCE DATABASE IMMEDIATE FORCE CONNECTIONS;
CONNECT RESET;
BACKUP DATABASE JOURNAL TO \"C:\\msk\" WITH 2 BUFFERS BUFFER 1024 PARALLELISM 1 WITHOUT PROMPTING;
CONNECT TO JOURNAL;
UNQUIESCE DATABASE;
CONNECT RESET;


из программы выполняю коннект к базе:
Код

Class.forName("COM.ibm.db2.jdbc.app.DB2Driver");
Connection conn = DriverManager.getConnection("jdbc:db2:journal");

а затем этот запрос:
Код

Statement st = conn.createStatement();
st.executeUpdate(sql);       // или     st.execute(sql);
st.close();
conn.close();

на execute выскакивает Exception про неверный синтаксис команды.
Если sql = "CONNECT TO JOURNAL";            -  та же ошибка

Помогите, пжлста, кто чем может!!
 smile 

P.S. Забыла сказать, что нужно это сделать обязательно программными средствами!!

Это сообщение отредактировал(а) Zhenyusya - 9.10.2008, 04:54
PM MAIL ICQ   Вверх
tux
Дата 9.10.2008, 08:32 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Летатель
***


Профиль
Группа: Участник Клуба
Сообщений: 1853
Регистрация: 10.2.2005
Где: msk.ru

Репутация: 74
Всего: 132



То, что вы пытаетесь выполнить - команды интерпретатора DB2, а не SQL-команды. Единственный выход - запускать DB2 CLP из java-приложения и передавать ему этот набор команд.
PM MAIL Skype GTalk Jabber YIM   Вверх
Zhenyusya
  Дата 13.10.2008, 04:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Вопрос решился просто:
запускаю команду 
Код

String cmd = "db2cmd C:\\msk\\restoreDB.cmd";
Runtime runtime = Runtime.getRuntime();
runtime.exec(cmd);
а в restoreDB.cmd последовательность команд для резервного копирования.
Вот и все!  smile 
PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

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

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


 




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


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

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