Хранение файлов 1С: Бухгалтерии предприятия во внешней СУБД. Расширение

16.11.18

Разработка - Инструментарий разработчика

Данное расширение предназначено для 1С БП 3.0.65.69. Его задача - разместить присоединенные файлы не внутри базы 1С, а во внешнем источнике.

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование По подписке [?] Купить один файл
Архив с расширением и инструкцией
.zip 903,78Kb ver:0.3
12
12 Скачать (6 SM) Купить за 3 350 руб.

Требования к системе

  1. Версия платформы 8.3.13. [1]
  2. Версия Бухгалтерии Предприятия 3.0.65.69.
  3. MS SQL Server 2008 R2 и старше.
  4. Клиент-серверный режим работы базы.[2]

Общий принцип работы

Данное расширение позволяет хранить файлы и изображения не в виде хранилища значения в реквизитах базы 1С, а во внешней SQL базе, что, в случае большого объема данных в файла, существенно экономит место на быстрых дисках и уменьшает время обслуживания баз (бекап, восстановление).

Расширение добавляет в конфигурацию справочник с настройками подключения к внешней базе SQL и регистр с указанием ссылки на эту настройку и идентификатором файла в этой базе. При прикреплении файлов в базу конфигурация ведет себя типовым образом, помещая файл внутрь базы 1С, однако внешняя обработка в составе расширения, при регламентном запуске будет переносить файлы по 1000 штук во внешнее хранилище. Считывание файла из базы переопределено расширением, в случае, если файл перемещен во внешнее хранилище, то он будет запрошен из него, если же хранится внутри базы 1С – то будет запрошен из нее.

Соответствие лицензионной политике 1С

Прямая цитата с сайта 1С:

«… обращаться к данным информационной базы только при помощи объектов "1С:Предприятия", специально предназначенных для работы с данными (запросы, справочники, документы и т.д.). Нельзя обращаться к данным информационной базы напрямую, минуя уровень объектов работы с данными "1С:Предприятия" - например при помощи средств СУБД или при помощи внешних компонент, которые реализуют прямой доступ к СУБД. Это ограничение распространяется на любые действия с данными, в том числе на изменение их структуры, а так же на чтение или изменение самих данных информационной базы или служебных данных "1С:Предприятия".»

Данное расширение работает с данными внутри базы 1С штатными средствами и обращается за хранимыми файлами во внешнюю базу, не нарушая таким образом лицензионное соглашение.

Дальнейшие планы

В расширении планируется реализовать следующий функционал:

  1. Механизм работы с несколькими хранилищами. На текущий момент система получает одно хранилище, которое пользователь установил основным, и сохраняет данные в нем. Пользователь может изменить это хранилище и новые файлы будут сохраняться уже в новое хранилище, а старый по прежнему будут храниться и открываться из старого. Планируется реализовать механизм, который позволит на основании некоторых входных данных определять, какое именно хранилище будет использовано при перемещении файла.
  2. Очистка хранилища. При пометке файла на удаление и удалении его из базы 1С, в случае использования расширения, из базы 1С удалится справочник прикрепленного файла и настройки связи справочника и внешнего хранилища. Однако, само содержимое файла так и останется во внешней базе. Для того, чтобы подобные файлы удалялись автоматически, нужно будет реализовать очистку внешних хранилищ от удаленных в базе 1С файлов.
  3. Реализовать хранение файлов на SQL сервере с использованием механизма FILESTREAM, когда файлы хранятся на диске сервера СУБД, а не в таблице базы. При этом, все операции над данными все равно происходят с учетом этих файлов на диске.

[1] Платформа должна поддерживать добавление расширением новых справочников и регистров сведений.

[2] Расширение можно использовать и для файловой базы, однако представляется маловероятным хранение в файловой базе такого объема присоединенных файлов, что для работы с ними было бы выгодно использовать внешнее хранилище. Так же в случае с файловой базой, вам придется решать вопрос с регламентным запуском самостоятельно, следуя инструкции к БСП.

См. также

Инструментарий разработчика Роли и права Запросы СКД Программист Руководитель проекта Платформа 1С v8.3 Управляемые формы Запросы Система компоновки данных Платные (руб)

Инструменты для разработчиков 1С 8.3: Infostart Toolkit. Автоматизация и ускорение разработки на управляемых формах. Легкость работы с 1С.

12000 руб.

02.09.2020    169993    939    403    

906

Инструментарий разработчика Чистка данных Свертка базы Инструменты администратора БД Системный администратор Программист Руководитель проекта Платформа 1С v8.3 Россия Платные (руб)

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку сразу нескольких баз данных и выполнять их автоматически без непосредственного участия пользователя. Решение в Реестре отечественного ПО

8400 руб.

20.08.2024    13045    100    46    

104

Инструментарий разработчика Программист Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Инструмент для написания и отладки кода в режиме «1С:Предприятие». Представляет собой консоль кода с возможностью пошаговой отладки, просмотра значений переменных любых типов, использования процедур и функций, просмотра стека вызовов, вычисления произвольных выражений на встроенном языке в контексте точки останова, синтаксического контроля и остановки по ошибке. В консоли используется удобный редактор кода с подсветкой, контекстной подсказкой, возможностью вызова конструкторов запроса и форматной строки.

9360 руб.

17.05.2024    26736    90    48    

134

Пакетная печать Печатные формы Инструментарий разработчика Программист Платформа 1С v8.3 Запросы 1С:Зарплата и кадры бюджетного учреждения 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 Платные (руб)

Инструмент, позволяющий абсолютно по-новому взглянуть на процесс разработки печатных форм. Благодаря конструктору можно значительно снизить затраты времени на разработку печатных форм, повысить качество и "прозрачность" разработки, а также навести порядок в многообразии корпоративных печатных форм.

22200 руб.

06.10.2023    16930    41    15    

75

SALE! %

Инструментарий разработчика Инструменты администратора БД Системный администратор Программист Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Россия Платные (руб)

Универсальный инструмент программиста для администрирования конфигураций. Сборник наиболее часто используемых обработок под единым интерфейсом.

4800 3840 руб.

14.01.2013    190710    1151    0    

918

Инструменты администратора БД Инструментарий разработчика Роли и права Программист Платформа 1С v8.3 Конфигурации 1cv8 Россия Платные (руб)

Расширение позволяет без изменения кода конфигурации выполнять проверки при вводе данных, скрывать от пользователя недоступные ему данные, выполнять код в обработчиках. Не изменяет данные конфигурации, легко устанавливается практически на любую конфигурацию на управляемых формах.

15000 руб.

10.11.2023    11456    40    27    

66

Инструментарий разработчика Платформа 1С v8.3 Конфигурации 1cv8 1С:ERP Управление предприятием 2 Платные (руб)

Разработка Конструктор автоматизированных рабочих мест "Конструктор АРМ" реализована в виде расширения и является универсальным инструментом для создания АРМ любой сложности в пользовательском режиме.

3600 руб.

27.12.2024    933    2    0    

5

Инструментарий разработчика Программист Платформа 1С v8.3 Конфигурации 1cv8 Россия Платные (руб)

Восстановление партий или взаиморасчетов, расчет зарплаты, пакетное формирование документов или отчетов - теперь все это стало доступнее. * Есть желание повысить скорость работы медленных алгоритмов! Но... * Нет времени думать о реализации многопоточности? * о запуске и остановке потоков? * о поддержании потоков в рабочем состоянии? * о передаче данных в потоки и как получить ответ из потока? * об организации последовательности? Тогда ЭТО - то что надо!!!

5000 руб.

07.02.2018    103996    244    100    

306
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. kwazi 475 16.11.18 21:39 Сейчас в теме
не очень понятно кто целевая аудитория данного решения. В чем преимущество скажем над хранением файлов в томах на диске?
Защищенность?
2. Silenser 613 16.11.18 23:59 Сейчас в теме
(1)Надежность, защищенность, удобство бекапа, прежде всего для больших объемов данных.
3. Silenser 613 20.11.18 10:00 Сейчас в теме
(2) Забыл еще один плюс: в случае, если нужно хранить скан или файл в нескольких системах, то можно настроить их так, чтобы содержимое файла хранилось единожды и было доступно по его ИД, хранимому в базе SQL, что для больших объемов будет существенно экономить место.
4. aspirator23 340 24.11.18 16:30 Сейчас в теме
(3) Для целей этой разработки, наверное лучше сразу использовать Filestream или даже NoSql. Быстродействие в текущей реализации скорее всего сносно, но не очень? Особенно если прочитать Дальнейшие планы. :)
5. Silenser 613 24.11.18 21:54 Сейчас в теме
(4)
Filestream

Тут не все так однозначно. Я не нашел интерфейса для считывания файлов в FileStream в режиме потока, минуя ядро MS SQL и процессор, без использования внешних компонент. Получать же файлы через результат запроса и просто хранить файлы вне СУБД можно, но смысл тогда каков? При больших объемах файловая система может начать подтормаживать. Для такого режима хранения рекомендуется проводить дефрагментацию. MS сама честно все об этом говорит. Я подумаю, как решить эту проблему, но использовать FileStream и получать файл через результат запроса не оптимально, ИМХО.

(4)
NoSql

Текущая версия позволяет использовать MongoDB через RESTHeart. Но опять же, какова конечная цель? Как раз недавно Инфостарт проводил опрос по используемым СУБД. Не так уж много людей используют что-то, кроме MS SQL в компаниях, где установлена 1С. Для того, чтобы держать файлы на NoSQL, требуется как минимум админ, который понимает, как настраивать и устанавливать эту СУБД, а так же пользователи, которые будут использовать именно ее. Я готов разработать механизм хранения в NoSQL, если меня заинтересуют ;), иначе это просто работа в корзину. Вторая по популярность СУБД - Postgress, тоже поддерживается моим расширением.

(4)
Быстродействие в текущей реализации скорее всего сносно, но не очень?

Быстродействие чего? Мое расширение работает довольно быстро, на уровне типового механизма хранения файлов в ХранилищеЗначения. Если речь про хранение файлов в режиме FileStream, то особой скорости обычно и не требуется. Важнее надежность.
6. aspirator23 340 25.11.18 08:24 Сейчас в теме
(5) Под быстродействием я понимал скорость записи файлов во внешнюю базу данных.

Кажется запись больших файлов в MSSQL, используя FileStream быстрее чем обычной записи.
Вот в тему публикация на инфостарте: https://infostart.ru/public/538764/

Другие рассуждения об этом:
http://download.microsoft.com/download/0/9/4/0947BFC2-9942-4365-ACAE-CEC9C7958E66/FILESTREAMStorage.docx
http://www.sql.ru/forum/1245719-2/kak-uluchshit-skorost-zapisi-chteniya-blobov
https://blogs.msdn.microsoft.com/alexejs/2009/06/03/filestream-3/
https://blogs.msdn.microsoft.com/alexejs/2009/06/09/563/

Nosql быстрее реляционной SQL.
https://xakep.ru/2014/01/11/nosql-bd-test/
https://cyberleninka.ru/article/v/sravnitelnyy-analiz-proizvoditelnosti-sql-i-nosql-subd

А вот пример на инфостарте для CouchDB . Наверное видел его?
https://infostart.ru/public/139279/
7. Silenser 613 25.11.18 23:54 Сейчас в теме
(6)
Кажется запись больших файлов в MSSQL, используя FileStream быстрее чем обычной записи.
Вот в тему публикация на инфостарте: https://infostart.ru/public/538764/

Видел эту публикацию. Интересно, но нужна ВК, чтобы проверить. Хотелось бы, конечно, через COM.

(6)
Nosql быстрее реляционной SQL

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

(6)
А вот пример на инфостарте для CouchDB . Наверное видел его?
https://infostart.ru/public/139279/

Видел, решил не повторяться.

(6)
Другие рассуждения об этом:

А вот это интересно, почитаем, спасибо.
8. OlegBog1971 27 14.01.20 09:24 Сейчас в теме
Добрый день.
Кто использовал данную разработку на "рабочих" базах?
Какие проблемы? Ограничения?
Встала задача перенести все хранящиеся в базе 1с файлы вложений на SQL.
Оставьте свое сообщение