4 / 4 / 0
Регистрация: 28.09.2012
Сообщений: 178
1

Хранение файлов и путей к ним

22.09.2019, 21:14. Показов 3334. Ответов 14
Метки нет (Все метки)

Здравствуйте. Есть клиент и бд на ms sql. Три основных Таблицы Т_Заказы, Т_Клиенты, Т_Объекты. В каждой есть поле «путь до папки» например: создали нового клиента, под него создали папку и туда складываем его Файлы, типа скан паспорта.. Создали объект «дом», под него создали папку и туда складываем его Файлы типа «паспорт объекта».... Создали заказ под него папку, куда складываем его Файлы типа «договор»....
Вот вопрос, как организовать хранение и доступность файлов.
Т.е. в заказе присутствует Клиент и Объект, но одним теже Клиенты объекты могут присутствовать в других заказах.
На данный момент реализация такая, в папке заказа создаются ярлыки до папок Клиент и Объект. Но это до жути не удобно.
Кто как реализует данную часть???
Спасибо.
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
22.09.2019, 21:14
Ответы с готовыми решениями:

Хранение звуковых файлов
Скажите пожалуйста, можно ли хранить в БД Access звуковые файлы (wav) и подключать их по id, в...

Хранение множества файлов...
Привет всем, подскажите пожалуйста, я дельфи знаю но с базами данных никогда не работал... Возник...

Хранение и отображение *.pdf файлов из базы mysql
Всем привет. Ребята, такое дело, есть приложение на delphi 7.0, с базой mysql, помогите реализовать...

Запрет на удаление файлов и путей к ним
файл использую на работе при случаях, когда у пользователя нехватка места подскачите, чего не...

14
1073 / 986 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
22.09.2019, 22:29 2
Лучший ответ Сообщение было отмечено Slalom как решение

Решение

Если поле таблиц назвать "путь до файла" и хранить все файлы в одной, заранее созданной на физ. сервере, папке, то проблемы резко сократятся.
В названии файла документа добавить лишь префикс (суффикс) от части или полного имени таблицы, с добавлением уникального идентификатора строки таблицы, к которой относится документ (чтобы гарантированно не было дубликатов в наименованиях файлов).
Записать полный путь файла в таблицу, отправить файл документа в хорошо известную папку на сервере, а затем, при необходимости, выбрать документ, переправить на клиентскую машину и там его показать - сложно не будет.

Как-то так.
1
882 / 584 / 179
Регистрация: 28.02.2017
Сообщений: 2,359
Записей в блоге: 1
22.09.2019, 23:23 3
Если файлы небольшие, но важные/нужные - можно запихивать в БД. Разумеется если на сервере и в СУБД хватит места.

Добавлено через 27 секунд
Можно в отдельную базу с именем "Документы".
0
5494 / 4289 / 1379
Регистрация: 14.04.2014
Сообщений: 19,274
Записей в блоге: 19
23.09.2019, 07:45 4
Лучший ответ Сообщение было отмечено Slalom как решение

Решение

Скандербег, добавлю, что предпочтительно файлы отдавать не через расшаривание папок, а завести хотя бы простенький WEB-сервер
1
1073 / 986 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
23.09.2019, 10:56 5
Разумеется, это один из вариантов и очень неплохой. Можно сказать, один из популярных на текущий момент.
Но есть конторы, у которых "политика" такова, что LAN запрещено соединять с Сетью.
0
5494 / 4289 / 1379
Регистрация: 14.04.2014
Сообщений: 19,274
Записей в блоге: 19
23.09.2019, 22:30 6
у большинства так
но ведь и веб-сервер необязательно выставлять наружу
в локальной сетке он прекрасно работает
просто это хорошая практика и потом когда возникнет необходимость можно взять готовое универсальное решение
0
1073 / 986 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
23.09.2019, 22:47 7
Да, конечно, всё так, полностью соглашусь.
Но окончательное решение, практически, зависит от инфраструктуры выч. системы, требований безопасности и квалификации разработчиков.
1
4 / 4 / 0
Регистрация: 28.09.2012
Сообщений: 178
24.09.2019, 00:24  [ТС] 8
Скандербег, krapotkin, GoodWeather, Спасибо вам за ответы. Буду изучать.
0
4 / 4 / 0
Регистрация: 28.09.2012
Сообщений: 178
25.09.2019, 07:31  [ТС] 9
krapotkin, Здравствуйте. Подскажите Наименование Веб серверов которые можно развернуть по локальной сети. (бесплатные))))

Добавлено через 3 минуты
krapotkin, желательно где есть мануал на русском)))
0
4855 / 4001 / 1005
Регистрация: 29.08.2013
Сообщений: 25,565
Записей в блоге: 3
25.09.2019, 09:24 10
Slalom, это ветка по делфи
тут вам могут подсказать как написать свой сервер на делфи
0
4 / 4 / 0
Регистрация: 28.09.2012
Сообщений: 178
25.09.2019, 11:32  [ТС] 11
qwertehok, ))) Я думаю колесо тут не стоит изобретать, уверен что krapotkin знает решение, и возможно поделится ссылкой)) А про другу ветку не знаю, стоит ли отдельная тема этого?
0
5494 / 4289 / 1379
Регистрация: 14.04.2014
Сообщений: 19,274
Записей в блоге: 19
25.09.2019, 14:13 12
какие вы знаете, все умеют! )))
и у всех есть русский ман
0
4 / 4 / 0
Регистрация: 28.09.2012
Сообщений: 178
25.09.2019, 14:54  [ТС] 13
krapotkin, ???

Добавлено через 1 минуту
я вообще не каких не знаю! (((
0
5494 / 4289 / 1379
Регистрация: 14.04.2014
Сообщений: 19,274
Записей в блоге: 19
25.09.2019, 15:02 14
IIS - вообще встроен в систему
apache
nginx
0
4 / 4 / 0
Регистрация: 28.09.2012
Сообщений: 178
25.09.2019, 15:30  [ТС] 15
krapotkin, Спасибо!
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
25.09.2019, 15:30
Помогаю со студенческими работами здесь

Поиск файлов в папке и получение путей к ним (консоль)
Все привет! Как выполнить поиск имеющихся файлов в папке и получить их адреса? Консольное...

Хранение большого количества файлов и быстрый доступ к ним
мне надо хранить загружаемые файлы чтобы доступ к любому файлу был очень быстрым. т.к. пути к...

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

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


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2023, CyberForum.ru