![]() |
Модераторы: LSD |
![]() ![]() ![]() |
|
isergey |
|
|||
Новичок Профиль Группа: Участник Сообщений: 30 Регистрация: 28.5.2008 Репутация: нет Всего: нет |
Задача: организация хранения и поиск по нечетко струкутированной информации.
В общем виде он выглядит так:
Т.е. как видно, datafield tag="553" может повторяться сколь угодно. Вопрос, как осуществлять поиск по этому XML в РДБ. Я пробовал хранить 12000 таких записей в MySQL и делать выборку через XPATH, но этот процесс выполнялся около секунды, что совершенно не подходит для задачи. Как можно ускорить обработку XML данных (в различных БД, желательно свободных), какие индексы использовать (можно ли индексировать отдельные ноды?). Заранее благодарю! Это сообщение отредактировал(а) isergey - 25.1.2010, 15:43 |
|||
|
||||
LSD |
|
|||
![]() Leprechaun Software Developer ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 15718 Регистрация: 24.3.2004 Где: Dublin Репутация: 24 Всего: 538 |
Ну нефига себе, секунда это долго? В принципе если XPath известен заранее, можно попробовать создать функциональный индекс по этому XPath. Добавлено через 40 секунд Или даже просто отдельную колонку с закэшированным вычисленным значением этого XPath. -------------------- Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it. |
|||
|
||||
isergey |
|
|||
Новичок Профиль Группа: Участник Сообщений: 30 Регистрация: 28.5.2008 Репутация: нет Всего: нет |
Расчетное количество хранимых документов несколько сотен тысяч. Т.е. выборка без индексов займет несколько десятков секунд. Вариант с колонками тоже не подходит.
Есть инструмент zebra2 от indexdata.com, с этой проблемой он справляется на раз (моментальная выдача результата), единственный минус, обновлять удалять добавлять записи крайне неудобно. Это сообщение отредактировал(а) isergey - 25.1.2010, 16:52 |
|||
|
||||
![]() ![]() ![]() |
Правила форума "Общие вопросы по базам данных" | |
|
Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:
Данный форум не предназначен для:
Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение.
Полезные советы: Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa. |
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | СУБД, общие вопросы | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |