Форум программистов, компьютерный форум, киберфорум
Алгоритмы
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.59/29: Рейтинг темы: голосов - 29, средняя оценка - 4.59
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
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
20.04.2013, 10:13
Ответы с готовыми решениями:

хранение путей.
Вопрос такой нужно хранить пути к файлом, прикрепленные к одной записи. Далее открывать файлы через эти пути стандартными средствами...

Хранение файлов и путей к ним
Здравствуйте. Есть клиент и бд на ms sql. Три основных Таблицы Т_Заказы, Т_Клиенты, Т_Объекты. В каждой есть поле «путь до папки» например:...

Хранение нескольких путей к файлам
Добрый вечер, интересует есть ли на ВФ клас который позволят взять адрес файла. код:using System; using System.Collections.Generic; ...

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
Цитата Сообщение от eugrita Посмотреть сообщение
При этом после SQL запроса выборки всех записей по данному маршруту, необходимо восстановить список т.е найти Nach без входящих узлов и Fin без исходящих узлов и т.д. Правда такое не годится для кольцевых маршрутов, так как непонятно где будет начальная (она же и конечная)остановка
Это-то как раз не проблема: начало/конец можно и отдельными полями хранить.
В общем, имхо, в любом варианте будь готов много дописывать. Задача достаточно сложная, и в SQL красиво не укладывается.
0
Эксперт функциональных языков программированияЭксперт Java
 Аватар для korvin_
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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.05.2013, 00:17
Помогаю со студенческими работами здесь

Хранение путей изображений в базе данных
Как хранить пути изображений в базе данных, может кто-то предоставить код это процесса ?

Как организовать хранение списка путей?
Задача заключается в том чтобы по нажатию кнопки сделать бэкап родных файлов, и заменить их (File.Copy) файлами из другой папки. Дело в том...

Нахождение всех путей ориетированного графа
Есть вектор с ребрами vector< vector<int> > g; Как найти все пути методом поиска в глубину например? Количество вершин, из каких в...

Посчитать длины кратчайших путей ориентированного графа
есть задача : задача №138 Алгоритм Форда-Беллмана (Время: 1 сек. Память: 16 Мб Сложность: 38%) Дан ориентированный граф, в котором...

Найти количество всех путей и контуров графа длиной S
Требуется найти количество всех путей и контуров графа длиной 7. Граф: 1 0 0 1 0 0 0 1 1 1 0 0 1 1 0 0 1 1 0 1 0 1 1 1 0 1 1...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Философия технологии
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 - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru