Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2002.12.19;
Скачать: CL | DM;

Вниз

XML и ADO! Нужна помощь!   Найти похожие ветки 

 
AMS ©   (2002-11-29 15:16) [0]

Условия задачи:
есть компонент TAdoDataSet. В него загружена информация из XML-файла (ADS.LoadFromFile(file)).
Надо:
Записать эту информацию в SQL Server 2000 во временную таблицу той же структуры. Метод UpdateBatch почему-то не работает. Пока делаю путём переписывания по одной записи из TAdoDataSet в TAdoTable. Но получается довольно медленно.

Что посоветуеуте - ЗНАТОКИ DELPHI 5 и 6.


 
asmith   (2002-11-29 18:14) [1]

Можно все вынести на SQL Server - передавать в хранимую процедуру имя файла, читать его там парсером MSXML, парсить и формировать insert-ы для вставки в таблицу.


 
AMS ©   (2002-11-29 18:51) [2]

Если Вы делали это практически, то не могли бы опубликовать или прислать примерчик, как это делается. Я думаю, что это непростая задача.


 
asmith   (2002-11-29 19:32) [3]

Если умешь работать с парсером MSXML или желаешь с этим разбираться (это отдельный разговор), то достаточно просто - работаешь через OLE-автоматизицию. SQL Server для этого содержит специальные хранимые процедуры (см. BOL, sp_OAXXX). Удобно сделать тестовый проектик на DELPHI и отладить парсинг там, а потом быстро перенести в SQL. Маленький примерчик привести трудно, так как реальные коды достаточно объемные из-за специфики процедур sp_OAXXX. Главная процедура преобразования вроде этого:

CREATE PROCEDURE xsp_PublicData2XMLDocument
@filename varchar(255),
@debug int = 0
AS
DECLARE @xmldoc int
DECLARE @hr int
DECLARE @publicdata int
DECLARE @packageheader int

-- Create an object.
exec @hr = sp_OACreate "Microsoft.XMLDOM", @xmldoc OUT
if @hr <> 0 and @debug = 1
begin
exec sp_displayoaerrorinfo @xmldoc, @hr
print "create XMLDOM"
return
end
-- load document
exec @hr = sp_OAMethod @xmldoc, "load", NULL, @filename
if @hr <> 0 and @debug = 1
begin
exec sp_displayoaerrorinfo @xmldoc, @hr
return
end
-- parse document here & build SQL INSERTs
-- Destroy the object.
exec @hr = sp_OADestroy @xmldoc
if @hr <> 0 and @debug = 1
begin
exec sp_displayoaerrorinfo @xmldoc, @hr
return
end



Страницы: 1 вся ветка

Текущий архив: 2002.12.19;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.016 c
1-61573
kepten
2002-12-09 07:40
2002.12.19
Borland kylix


4-61875
Damage
2002-11-05 21:55
2002.12.19
свойства документов (.doc) в эксплорере


1-61638
Slavik99
2002-12-07 12:30
2002.12.19
Установка покетов в Delphi 5


4-61858
9999
2002-11-05 17:42
2002.12.19
Убить процесс при помощи Delphi


1-61603
Che
2002-12-10 00:01
2002.12.19
IdHTTP и циклы !!! ПОМОГИТЕ plz