Перенос файлов из томов в информационную базу для 1С Документооборот

04.02.14

База данных - Инструменты администратора БД

Изменение способа хранения вложений (из файлов в БД) и копирование всей информации

Файлы

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

Наименование Скачано Купить файл
ПереносИзТомовВБазу
.epf 6,89Kb
84 2 500 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

Вы можете заказать платную доработку или адаптацию этой разработки под вашу конфигурацию на «Бирже заказов».

  • 0% комиссии — оплата напрямую исполнителю;
  • Исполнители любого масштаба — от отдельных специалистов до команд под проект;
  • Прямой обмен контактами между заказчиком и исполнителем;
  • Безопасная сделка — при необходимости;
  • Рейтинги, кейсы и прозрачная система откликов.

После года работы с конфигурацией было принято политическое решение перенести накопленные гигабайты внутрь БД. Поиском нашлись лишь стандартные входящие в поставку Документооборота обработки ПереносФайловВТома_ХХХ.epf.
По фразе "смена способа хранения файлов" ничего ценного найдено не было. При простом переключении в настройках варианта хранения переноса файлов из одного места в другое не происходит. Пришлось писать свою обработку.

К счастью в Документообороте хранение организовано просто без заморочек. Задействованы лишь несколько объектов: справочник ВерсииФайлов, регистр сведений ХранимыеФайлыВерсий и перечисление ТипыХраненияФайлов.

Суть переноса: копирование содержимого файла и запись в хранилище значения в регистре с заменой нескольких реквизитов в справочнике. Ниже код для переноса под Windows.

	// идем по все элементам справочника ВерсииФайлов 	
Запрос = Новый Запрос; Запрос.Текст = "ВЫБРАТЬ
                | ВерсииФайлов.Ссылка,
                | ВерсииФайлов.ПутьКФайлу,
                | ВерсииФайлов.Размер,
                | ВерсииФайлов.Том.ПолныйПутьWindows Как ПолныйПутьWindows
                |ИЗ
                | Справочник.ВерсииФайлов КАК ВерсииФайлов
                |УПОРЯДОЧИТЬ ПО
                | ВерсииФайлов.ДатаСоздания"
; РезультатЗапроса = Запрос.Выполнить(); ВДЗ = РезультатЗапроса.Выбрать(); Пока ВДЗ.Следующий() Цикл Если ВДЗ.ПутьКФайлу="" Тогда
                       
Продолжить;
                КонецЕсли; ПолныйПуть = ВДЗ.ПолныйПутьWindows+ВДЗ.ПутьКФайлу; Попытка
Файл = Новый ДвоичныеДанные(ПолныйПуть); ХЗ = Новый ХранилищеЗначения(Файл); Исключение
Сообщить(ВДЗ.ПутьКФайлу + " считывание и помещение в ХЗ породило ошибку: "+ОписаниеОшибки()); Продолжить; КонецПопытки; // обновим запись РС
Попытка
 
        МенеджерЗаписи = РегистрыСведений.ХранимыеФайлыВерсий.СоздатьМенеджерЗаписи(); МенеджерЗаписи.ВерсияФайла = ВДЗ.Ссылка; МенеджерЗаписи.ХранимыйФайл = ХЗ; МенеджерЗаписи.Записать(Истина); Исключение
Сообщить(ВДЗ.Ссылка + " попытка записи в РС не удалась: "+ОписаниеОшибки()); Продолжить; КонецПопытки; // обновили Об = ВДЗ.Ссылка.ПолучитьОбъект(); Об.ПутьКФайлу = ""; Об.ТипХраненияФайла = Перечисления.ТипыХраненияФайлов.ВИнформационнойБазе; Об.Том = Справочники.ТомаХраненияФайлов.ПустаяСсылка(); Об.Записать(); КонецЦикла;


Перед выполнением обработки нужно в настройках документооборота убрать галку "Хранить файлы в томах на диске" (Настройки программы - Файлы).

На время выполнения обработки на всякий случай запретил сеансы и регламентные задания, выгнал всех из базы. Объем 2.2Гб переносился около 15 минут. Из 3500+ файлов не перенеслось три (физически отсутствовали файлы на диске по неизвестной пока причине). Но на целостность и работоспособность Документооборота они не влияют.
После успешного переноса файловое хранилище больше не потребуется, можно снести или убрать в архив.

p.s. В приложении готовая обработка по описанному алгоритму, сдобренная кнопочками и рюшечками.

Вступайте в нашу телеграмм-группу Инфостарт

перенос способ хранения

См. также

Инструментарий разработчика Чистка данных Свертка базы Инструменты администратора БД Системный администратор Программист Руководитель проекта 1С:Предприятие 8 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Россия Платные (руб)

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

24900 руб.

20.08.2024    68088    357    164    

312

Инструменты администратора БД Инструментарий разработчика Роли и права Программист 1С:Предприятие 8 1C:Бухгалтерия Россия Платные (руб)

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

17000 руб.

10.11.2023    25249    93    46    

102

Инструменты администратора БД Роли и права Системный администратор Программист Пользователь 1С 8.3 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Документооборот 1С:Зарплата и кадры государственного учреждения 3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Платные (руб)

Роли… Вы тратите много времени и сил на подбор ролей среди около 2400 в ERP или 1500 в Рознице 2, пытаясь понять какими правами они обладают? Вы все время смотрите права в конфигураторе или отчетах чтоб создать нормальные профили доступа? Вы хотите наглядно видеть какие права дает профиль и редактировать все в простом виде? А может хотите просто указать подсистему и дать права на просмотр и добавление на объекты и не лезть в дебри прав и чтоб обработка сама подобрала нужные роли? Все это теперь стало возможно! Обновление от 17.04.2026, версия 1.4.1, работает в 1С:ФРЕШ!

24400 руб.

06.12.2023    22700    80    10    

113

Закрытие периода Инструменты администратора БД Корректировка данных Бухгалтер Пользователь 1С:Предприятие 8 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Платные (руб)

Расширение «Оперативное проведение» в 4 раза уменьшает время проведения документов и закрытия месяца. Является комплексным решением проблем 62 и 60 счетов. Оптимизирует проведение при включенной функциональной опции «Раздельный учет НДС». Используется в более 10 организациях уже 2 года. Совместимо с конфигурацией Бухгалтерия 3.0 (+КОРП).

14640 руб.

29.04.2020    50150    136    162    

92

Информационная безопасность Инструменты администратора БД Инструментарий разработчика Учет документов Системный администратор Программист Бизнес-аналитик Бухгалтер Пользователь Руководитель проекта 1С 8.3 1С 8.5 Розничная и сетевая торговля (FMCG) Платные (руб)

Контроль ввода данных в 1С: проверка заполнения реквизитов, обязательные поля, контроль перед записью и проведением, запрет проведения документа. Позволяет настраивать любые проверки данных в 1С 8.3/8.5 от обязательных полей до сложных условий – без открытия конфигуратора и написания кода. Готовое расширение, которое подключается и работает сразу.

6000 руб.

15.04.2026    1633    2    0    

20

Файловый обмен (TXT, XML, DBF), FTP Поиск данных Инструменты администратора БД Корректировка данных Системный администратор Программист 1С:Предприятие 8 1C:Бухгалтерия 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Платные (руб)

Данная обработка позволит Вам легко и просто, а главное - быстро, выполнить сравнение данных между ЛЮБЫМИ базами (и РИБ, по правилам конвертаций) по контрольным суммам выбранных объектов баз 1С, работающих на платформах 8.3 и выше. Удобный и понятный интерфейс в виде "мастера". Высокая скорость сравнения достигается за счет специального алгоритма расчета контрольной суммы объекта/записи и сравнения по данным суммам объектов 2х баз через файл. Имеется возможность выбора реквизитов, по которым система будет сравнивать объекты. Сравнение количества записей в движениях документов, возможность сравнивать данные по правилам конвертации и не только! Выбор объектов конфигурации для КАЖДОГО узла в отдельности с индивидуальным отбором для каждого объекта конфигурации, работа с FTP, сохранение или загрузка настроек, сохранение или загрузка результата сравнения, регистрация на обмен объекта и его движений. (Обновление от 12.11.2024, версия 2.2-2.5)

24400 руб.

27.10.2017    45936    31    13    

49

Чистка данных Инструменты администратора БД Администрирование 1С 8.3 1С:Документооборот 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Управление холдингом 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Платные (руб)

Решение представляет собой набор из 6 обработок для 1С по удалению организаций и справочников из базы по фильтрам, документов по фильтрам, универсальное сжатие данных, очистка битых движений регистратора, удаление устаревших регистров сведений, удаление устаревших документов "Электронное письмо входящее" и "Электронное письмо исходящее"

23999 руб.

20.02.2026    1243    1    0    

4
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. higs 05.02.14 06:58 Сейчас в теме
Здорово! Полезный механизм. Были мысли поступить с хранением файлов также.
Однако, у нас не за год 2 гига, а за месяц после начала работы уже гиг файлов. С одной стороны, бекап скульной базы все вытерпит, с другой, эти файлы и так лежат в рейдовом массиве.
Но возможность все же вернуть в базу - очень хорошо! Спасибо!
2. kraynev-navi 700 05.02.14 10:13 Сейчас в теме
Один из доводов в пользу переезда в ИБ - все в одном месте. Тем более опыт с хранением внутри базы у нас положительный: на другой конфе в день +100 мегов и все нормально работает.
3. FractonKireyev 05.02.14 13:29 Сейчас в теме
Я достаточно давно нечто подобное делал. На практике целостность хранения внутри БД выше, чем в томах на диске, если-бы изначально всё хранилось в БД - то не было-бы 3-х потерянных файлов...
Единственный совет, который хочется дать по поводу данного модуля - документы лучше хранить в сжатом виде. Т.е. в тексте модуля написать:

ХЗ = Новый ХранилищеЗначения(Файл, Новый СжатиеДанных( 9 ) );
// 9 - это максимальное сжатие. которое поддерживает платформа

Это никак не повлияет на выделение текста и индексирование (в документообороте это происходит при записи файла в БД), а вот размер базы сократится существенно. На быстродействие в процессе работы это так-же практически не влияет.
4. kraynev-navi 700 05.02.14 17:57 Сейчас в теме
(3) Попробовал на тестовой базе вашу идею с максимальным сжатием. Занимаемый объем уменьшился на 8%. Быстродействие не измерял.
5. ChasovskiH 2 30.09.14 09:15 Сейчас в теме
После переноса файлов в БД База работает медленнее((((
8. kraynev-navi 700 30.09.14 12:46 Сейчас в теме
(5) На сколько медленнее? По ощущениям? :) Большая база?
10. ChasovskiH 2 16.10.14 11:43 Сейчас в теме
(8) заметно медленнее "тормозит по страшному" база 80 Гб Лучше хранить файлы отдельно.ну это из моего опыта
6. ChasovskiH 2 30.09.14 09:16 Сейчас в теме
А есть ли в этой обработке возможность переноса файлов наоборот из БД в тома???
7. kraynev-navi 700 30.09.14 12:44 Сейчас в теме
(6) В данной обработке нет. Но, если мне не изменяет память что-то было в комплект поставки самого ДО. Сейчас нет под рукой данной конфигурации, проверить не могу.
11. ChasovskiH 2 16.10.14 11:48 Сейчас в теме
(9) ansh15, а к чему мне эта статья? Я исхожу из своего опыта в работе с Документооборотом1с
13. ansh15 16.10.14 13:44 Сейчас в теме
(11) Там ответ на ваш вопрос.
12. ChasovskiH 2 16.10.14 11:53 Сейчас в теме
Если говорить проще, Лучше когда в базе хранятся прямые ссылки на файлы в томах. Т.е. при открытии файла не переворачивается вся база в поисках нужного, а открывает его по прямой ссылке.Если же все файлы хранятся в базе, при обращении к файлу система начинает его искать так как ссылки то прямой нет.!!!Как считаете при каком способе хранения база быстрей работать будет???
14. stas1kbob 60 11.09.15 12:39 Сейчас в теме
не работает в документообороте 2.0
18. kraynev-navi 700 10.08.16 13:27 Сейчас в теме
(14) Да. Когда обработка писалась ДО 2.0 в проекте не было )))
15. vasa444 04.07.16 11:11 Сейчас в теме
kraynev-navi хочу обсудить с вами работу свяжитесь со мной пожалуйста по почте sergeykmk2@yandex.ru
16. Cybersant 09.08.16 17:36 Сейчас в теме
Подойдёт ли обработка для бухгалтерии 3.0?
17. kraynev-navi 700 10.08.16 13:25 Сейчас в теме
(16) Увы, БП3 с файлами у нас нет, проверить не могу.
19. Cybersant 11.08.16 14:01 Сейчас в теме
(17)
можно попросить поделитесь обработкой, прислав на почту? Как раз смогу потестировать
20. Cybersant 15.08.16 13:22 Сейчас в теме
Протестировал с БП, ред. 3.0; увы, не работает(
21. user2078556 06.04.24 14:35 Сейчас в теме
Всем Добра! Протестил на ДО 1.4.. Вроде как длительный процесс и возрастание самой базы указывают на то что файлы перенеслись в базу.. НО! Но при отключении (переносе в другое место) тома с файлами, при попытке открыть любой файл в базе происходит ошибка о недоступности.. Подскажите, что могло пойти не так?
Для отправки сообщения требуется регистрация/авторизация