Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2002.12.19;
Скачать: [xml.tar.bz2];

Вниз

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;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.46 MB
Время: 0.013 c
14-61767
Дмитрий К.К.
2002-11-27 15:50
2002.12.19
Total Commander


3-61476
victor_ch
2002-12-02 11:56
2002.12.19
Уменьшение потребления памяти


7-61843
Иван
2002-09-30 09:59
2002.12.19
Перехват чтения с дискеты


1-61676
kucherav
2002-12-08 17:07
2002.12.19
Somebody help!!!!!!


14-61801
Anatoly Podgoretsky
2002-11-28 07:49
2002.12.19
Именинники 28 ноября





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский