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

16.11.18

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

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

Скачать файлы

Наименование Файл Версия Размер
Архив с расширением и инструкцией
.zip 903,78Kb
12
.zip 0.3 903,78Kb 12 Скачать

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

  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] Расширение можно использовать и для файловой базы, однако представляется маловероятным хранение в файловой базе такого объема присоединенных файлов, что для работы с ними было бы выгодно использовать внешнее хранилище. Так же в случае с файловой базой, вам придется решать вопрос с регламентным запуском самостоятельно, следуя инструкции к БСП.

См. также

SALE! 20%

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

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

Набор инструментов программиста и специалиста 1С для всех конфигураций на управляемых формах. В состав входят инструменты: Консоль запросов, Консоль СКД, Консоль кода, Редактор объекта, Анализ прав доступа, Метаданные, Поиск ссылок, Сравнение объектов, Все функции, Подписки на события и др. Редактор запросов и кода с раскраской и контекстной подсказкой. Доработанный конструктор запросов тонкого клиента. Продукт хорошо оптимизирован и обладает самым широким функционалом среди всех инструментов, представленных на рынке.

10000 8000 руб.

02.09.2020    122319    673    389    

716

SALE! 25%

Infostart PrintWizard

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

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

18000 15300 руб.

06.10.2023    7333    22    6    

39

SALE! 20%

Infostart УДиФ: Управление данными и формами

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

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

10000 8000 руб.

10.11.2023    3603    11    1    

34

SALE! 30%

PowerTools

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

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

3600 2520 руб.

14.01.2013    177796    1074    0    

850

Многопоточность. Универсальный «Менеджер потоков» 2.1

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

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

5000 руб.

07.02.2018    99369    239    97    

296

[ЕХТ] Фреймворк для Расширений 1С

Инструментарий разработчика Платформа 1С v8.3 Управляемые формы Платные (руб)

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

3000 руб.

27.08.2019    18136    6    8    

40

1С HTML Шаблоны / HTML Templates

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

Быстрая и удобная обработка для работы с шаблонами HTML. Позволяет легко и быстро формировать код HTML.

2040 руб.

27.12.2017    28117    3    10    

15

Выполнение произвольного кода или запроса с параметрами через Web-сервис (замена COM-подключений)

Инструментарий разработчика Обмен между базами 1C Платформа 1С v8.3 Платные (руб)

В процессе работы в 1С часто возникает потребность получить данные из другой базы.  Обычно это делается через COM-соединение, и время выполнения запроса при этом оставляет желать лучшего. В данной публикации представлено универсальное решение, позволяющее практически моментально выполнить произвольный код или запрос с параметрами в другой информационной базе через Web-сервис.

2400 руб.

24.09.2019    23606    15    15    

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