Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 29.12.2009, 09:25
Cooper Cooper вне форума
Прохожий
 
Регистрация: 29.12.2009
Сообщения: 4
Репутация: 10
По умолчанию Экспорт из XML в ADO

Здравствуйте
Существует 2 базы данных с одинаковой структурой. Необходимо передать данные по следующей схеме:
бд1.таблица1 -> файл.xml
файл.xml -> бд2.таблица1

Для сохранения данных в xml я использую:
ADODataSet1.SaveToFile('d:\Local.XML', pfXML);

Для загрузки:
ADODataSet1.LoadFromFile('d:\Local.XML');
DataSource1.DataSet:=ADODataSet1;

В результате данные помещаются только в DBGrid1, а нужно их поместить в БД. Как мне отправить данные из DBGrid1 в таблицу БД?
Ответить с цитированием
  #2  
Старый 29.12.2009, 10:17
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Да как-бы и не надо их помещать в DBGrid. Обходите весь полученный набор в ADODataSet1 добавляя из него записи в таблицу БД.
Собственно DataSource1.DataSet:=ADODataSet1 - тоже нафик не нужно.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #3  
Старый 29.12.2009, 11:39
Cooper Cooper вне форума
Прохожий
 
Регистрация: 29.12.2009
Сообщения: 4
Репутация: 10
По умолчанию

Цитата:
Сообщение от Страдалецъ
Обходите весь полученный набор в ADODataSet1 добавляя из него записи в таблицу БД.
Вы предлагаете записи из ADODataSet1 добавлять в БД через цикл запросов INSERT? или есть способ ADODataSet -> БД? Не совсем понял
Ответить с цитированием
  #4  
Старый 29.12.2009, 12:22
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Верно, обычным инсертом. Это конечно медленне чем пакетом вставлять, зато просто и за процессом можно проследить.
Можно еще запросом, но я не готов на всидку написать такой запрос синтаксически правильно.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #5  
Старый 29.12.2009, 12:32
Cooper Cooper вне форума
Прохожий
 
Регистрация: 29.12.2009
Сообщения: 4
Репутация: 10
По умолчанию

Печально. Это сколько времени потребуется чтобы обновить таблицу в 350000 строк через sql-запросы на Pentium 866...
Но все равно спасибо за помощь
Ответить с цитированием
  #6  
Старый 29.12.2009, 15:14
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,004
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Не так много, как кажется.
Главное отключить визуальщину и делать это в одельной транзакции.

А вообще-то, делают не так.
Обновляют только то, что изменилось.
Сделай триггер, который при инсерте и удейте таблицы сваливает в отдельную табличку идюки изменненых/добавленых записей. А потом передавай только эти записи.
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

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

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 01:11.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter