|
5 / 6 / 4
Регистрация: 18.11.2009
Сообщений: 661
|
|
Хранение маршрутов (путей графа) в БД20.04.2013, 10:13. Показов 6077. Ответов 6
Метки нет (Все метки)
Что-то без поллитры не соображу как хранить маршруты в базе данных. Маршрут -динамическая структура,
имеет переменное число промежуточных пунктов. Можно конечно закодировать все пункты и представить маршрут как последовательность кодов пунктов Вижу 2 альтернативы 1)Хранение маршрута каждый узел в своем поле БД Недостатки - число полей БД фиксировано и можно лишь зарезервировать, например 30 или 50. Длину маршрута хранить в 1 поле. SQL запросы будут страшно длинными, неудобно, нужно каждый раз формировать в программном цикле. Достоинства. Каждое поле-узел табл.reis можно связать каскадной связью с табл. узлов Node - т.е автоматич поддержка ссылочной целостности. 2)Хранение маршрута в строковом (или веществ)поле. резервируется мах число узлов например N=100 Каждый узел кодируется тогда 2 символами Недостатки - сложность раскодирования. Писать программу разбивающая строку на пары соседн символов и преобразующие их в NN узлов. Никакой поддержки ссылочной целостности. Если тип поля вещественный - доп.проблема БД обрезает ведущие нули скажем цепочка узлов 0 -2 -10 представленная как 000110 обрежется в БД до 110 Единственное достоинство - удобное хранение в длинном текстовом поле (длина 200 и выше) Добавлено через 38 минут Отдельной проблемой является хранение сопутствующих маршруту данных. Например расписания и стоимости проезда Их уже так не закодируешь как в 1 случае. Если скажем стоимость проезда между 2 пунктами аддитивно зависит от стоимости проезда по каждому ребру, то можно скажем хранить атрибуты стоимости и время движения в табл ребер . Но в жизни это не всегда так. Кроме того можно учитывать особенности расписания - например некоторые пункты проезжают без остановки, тогда сумм время будет меньше суммы времен
0
|
|
| 20.04.2013, 10:13 | |
|
Ответы с готовыми решениями:
6
хранение путей.
Хранение нескольких путей к файлам |
|
432 / 433 / 93
Регистрация: 16.07.2012
Сообщений: 886
|
|
| 20.04.2013, 13:53 | |
|
Как насчет таблицы
"Идентификатор маршрута" "Порядковый номер пункта в маршруте" "Идентификатор очередного пункта"? Или такой "Идентификатор маршрута" "Порядковый номер отрезка" "Идентификатор начального пункта отрезка" "Идентификатор конечного пункта отрезка"?
0
|
|
|
5 / 6 / 4
Регистрация: 18.11.2009
Сообщений: 661
|
|
| 27.04.2013, 10:00 [ТС] | |
|
Да, именно такая структура табл удобна
Id_route -идентификатор маршрута Nach - идентификатор узла начального пункта текущей ветви Fin - идентификатор узла конечного пункта текущей ветви При этом после SQL запроса выборки всех записей по данному маршруту, необходимо восстановить список т.е найти Nach без входящих узлов и Fin без исходящих узлов и т.д. Правда такое не годится для кольцевых маршрутов, так как непонятно где будет начальная (она же и конечная)остановка ------------------------------------------------------------- А дальше можно составить подчиненную к табл маршрутов табл расписаний с ключами Id_route Tstart - время выезда
0
|
|
|
432 / 433 / 93
Регистрация: 16.07.2012
Сообщений: 886
|
|
| 27.04.2013, 10:56 | |
|
Ага, только обратите внимание - я не зря указал дополнительное поле для порядкового номера отрезка - в общем случае порядок в котором СУБД будет возвращать отрезки для заданного маршрута не определен (может быть любым).
0
|
|
|
2895 / 1930 / 208
Регистрация: 05.06.2011
Сообщений: 5,673
|
||
| 27.04.2013, 14:34 | ||
|
В общем, имхо, в любом варианте будь готов много дописывать. Задача достаточно сложная, и в SQL красиво не укладывается.
0
|
||
|
4575 / 2774 / 491
Регистрация: 28.04.2012
Сообщений: 8,765
|
|
| 27.04.2013, 15:16 | |
|
А почему бы в таком случае не посмотреть на NoSQL базы данных? В частности на хранилища графов.
0
|
|
|
5 / 6 / 4
Регистрация: 18.11.2009
Сообщений: 661
|
|
| 12.05.2013, 00:17 [ТС] | |
|
Вот в результате раздумий остановился на схеме
Какая-то ссылочная целостность (неполная)поддерживается. Так нельзя вставить в маршрут не вершину графа. Но контроль на существование ребра возложен не на СУБД а на программиста.т.е. ребро между соседними остановками это поля Routes.N между каждыми соседними Routes.nost (nost - порядковы1 N остановки от начала маршрута) Достоинства- минимум полей
0
|
|
| 12.05.2013, 00:17 | |
|
Помогаю со студенческими работами здесь
7
Хранение путей изображений в базе данных
Нахождение всех путей ориетированного графа Посчитать длины кратчайших путей ориентированного графа Найти количество всех путей и контуров графа длиной S Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
|
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога
В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
|
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
|
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога
Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
|
|
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
|
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования.
Часть библиотеки BedvitCOM
Использованы. . .
|
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога
SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
|
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога
SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
|