Rambler's Top100
"Knowledge itself is power"
F.Bacon
Поиск | Карта сайта | Помощь | О проекте | ТТХ  
 Круглый стол
  
Правила КС
>> Настройки

Фильтр вопросов
>> Новые вопросы
отслеживать по
>> Новые ответы

Избранное

Страница вопросов
Поиск по КС


Специальные проекты:
>> К л ю к в а
>> Г о л о в о л о м к и

Вопрос №

Задать вопрос
Off-topic вопросы

Помощь

 
 К н и г и
 
Книжная полка
 
 
Библиотека
 
  
  
 


Поиск
 
Поиск по КС
Поиск в статьях
Яndex© + Google©
Поиск книг

 
  
Тематический каталог
Все манускрипты

 
  
Карта VCL
ОШИБКИ
Сообщения системы

 
Форумы
 
Круглый стол
Новые вопросы

 
  
Базарная площадь
Городская площадь

 
   
С Л С

 
Летопись
 
Королевские Хроники
Рыцарский Зал
Глас народа!

 
  
ТТХ
Конкурсы
Королевская клюква

 
Разделы
 
Hello, World!
Лицей

Квинтана

 
  
Сокровищница
Подземелье Магов
Подводные камни
Свитки

 
  
Школа ОБЕРОНА

 
  
Арсенальная башня
Фолианты
Полигон

 
  
Книга Песка
Дальние земли

 
  
АРХИВЫ

 
 

Сейчас на сайте присутствуют:
 
  
 
Во Флориде и в Королевстве сейчас  10:45[Войти] | [Зарегистрироваться]
Ответ на вопрос № 47213

29-11-2006 08:02
Здравствуйте.

Возможно ли загрузить файл формата xml в ClientDataSet не полностью, а несколько записей. Например первые 100, потом следующие 100 и т.д.

Файл xml большого размера и при его зарузке компик начинает тормозить.

Если с помощью ClientDataSet это сделать нельзя, напишите пожалуйста как бы Вы это сделали.

Заранее благодарен.

[+] Добавить в избранные вопросы

Отслеживать ответы на этот вопрос по RSS

Ответы:


Уважаемые авторы вопросов! Большая просьба сообщить о результатах решения проблемы на этой странице.
Иначе, следящие за обсуждением, возможно имеющие аналогичные проблемы, не получают ясного представления об их решении. А авторы ответов не получают обратной связи. Что можно расценивать, как проявление неуважения к отвечающим от автора вопроса.

31-01-2007 07:31
TClientDataSet.PacketRecords ?

30-11-2006 05:23
Если Вы сами создаете XML или имеете полномочия сформировать требования к нему, то, может быть, стоит создавать вместо одного большого несколько файлов поменьше и считывать их последовательно?

30-11-2006 04:33
На счёт своего ответа я не уверен... В MSXML есть ISAXXMLReader (почитай в инете про SAX, кажется оно позволяет читать дерево не загружая весь документ, естественно это только для чтения).

30-11-2006 03:12 | Сообщение от автора вопроса
Первое пробовал. Грузит очень долго даже 300 мб файл. ClientDataSet загружает быстрее.

О втором варианте тоже думал. Прийдется его использовать. Можно взять заголовок файла Xml  и конец. А посредине вставлять записи из файла. Считываем 100 заисей добавляем заголовок и конец xml файла. Открываем датасет с этими записями. Потом следующие 100 записей и т.д.

30-11-2006 02:45
Альтернативные варианты:
1) разбирать xml файл с помощью какого-нибудь xml-парсера, извлекать оттуда нужные значения и добавлять в БД запросом. Например это можно сделать с помощью TXmlDocument. Правда есть сомнения, что это будет быстро. Насколько я понимаю, парсер xml сначала разбирает весь файл и строит дерево документа. Но можно попробовать, это просто и быстро (в смысле быстро - попробовать). Можно еще попробовать выбрать парсер, используемый TXmlDocument. По умолчанию это msxml, но стандартно присутствуют еще 2 по-моему, можно попробовать их (свойство TXmlDocument.DomVendor).
2)Если известна структура документа, то разбирать его самому: открыть как текстовый файл, считывать кусок текста, разбирать, находить знчения и добавлять их в БД и т.д. до конца документа.

30-11-2006 01:34 | Сообщение от автора вопроса
а если данных 2-3 гб ничего не будет. он наглухо не зависнет.

29-11-2006 12:06
to xr007
Ставьте тип ответа "сообщение от автора вопроса"
Если Вам всё-равно ВСЕ данные нужно переливать, чего ж мучаться с разделением пачек информации, повесьте красивый прогрессбарчик и вперед! Залить-то всё-равно нужно.

29-11-2006 10:36 | Сообщение от автора вопроса
Настоящая субд есть - Oracle. Надо туда как раз из xml данные внести.

29-11-2006 09:32
Я бы посоветовал вам перейти на настоящую СУБД

29-11-2006 08:29 | Сообщение от автора вопроса
во время того, как ClientDataSet подгружает xml, комп тормозит. оперативка расходуется. файл может быть в принципе любого размера. больше гигабайта тоже. Вы правильно поняли что данные надо в базу добавить, только как это сделать так чтобы они не сразу все брались из файла, а понемногу.

29-11-2006 08:15
Если формат фиксированный, то я бы "заливал" его в БД. А оттуда можно многое. А постоянно терзать винт текстовыми данными, да еще и парсить их каждый раз ... мне кажется не позволительной роскошью ...
(если я правильно понял вопрос)

Добавьте свое cообщение

Вашe имя:  [Войти]
Ваш адрес (e-mail):На Королевстве все адреса защищаются от спам-роботов
контрольный вопрос:
Однажды, в студеную зимнюю пору я из лесу вышел, был сильный ЧТО?
в качестве ответа на вопрос или загадку следует давать только одно слово в именительном падеже и именно в такой форме, как оно используется в оригинале.
Надоело отвечать на странные вопросы? Зарегистрируйтесь на сайте.
Тип сообщения:
Текст:
Жирный шрифт  Наклонный шрифт  Подчеркнутый шрифт  Выравнивание по центру  Список  Заголовок  Разделительная линия  Код  Маленький шрифт  Крупный шрифт  Цитирование блока текста  Строчное цитирование
  • вопрос Круглого стола № XXX

  • вопрос № YYY в тесте № XXX Рыцарской Квинтаны

  • сообщение № YYY в теме № XXX Базарной площади
  • обсуждение темы № YYY Базарной площади
  •  
     Правила оформления сообщений на Королевстве

    Страница избранных вопросов Круглого стола.
      
    Время на сайте: GMT минус 5 часов

    Если вы заметили орфографическую ошибку на этой странице, просто выделите ошибку мышью и нажмите Ctrl+Enter.
    Функция может не работать в некоторых версиях броузеров.

    Web hosting for this web site provided by DotNetPark (ASP.NET, SharePoint, MS SQL hosting)  
    Software for IIS, Hyper-V, MS SQL. Tools for Windows server administrators. Server migration utilities  

     
    © При использовании любых материалов «Королевства Delphi» необходимо указывать источник информации. Перепечатка авторских статей возможна только при согласии всех авторов и администрации сайта.
    Все используемые на сайте торговые марки являются собственностью их производителей.

    Яндекс цитирования