Перенос присоединенных файлов в тома

23.12.19

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

Обработка для переноса присоединенных файлов в тома.

Файлы

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

Наименование Скачано Купить файл
(только для физ. лиц)
Перенос присоединенных файлов в том 11.1 - 11.3
.epf 7,18Kb ver:1
208 1 850 руб. Купить
Перенос присоединенных файлов в том 11.4
.epf 7,13Kb ver:2
46 1 850 руб. Купить

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

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

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

Объем присоединенных файлов достиг 75% от объема БД. Резервное копирования и разворачивание БД для разработчиков стало занимать много времени. Принято решение перенести все присоединенные файлы в тома.

 

Обработка написана на основе типовой обработки "Перенос файлов в тома" конфигурации УТ 11.1.10.94.

Типовая обработка переносит файлы по справочнику «Версии файлов» из регистра сведений «Хранимые файлы версий», а предлагаемая по всем справочникам присоединенных файлов из регистра сведений «Присоединенные файлы». В обработке формируется текст запроса по метаданным, содержащим "Присоединенные файлы" в наименовании и типом хранения в информационной базе. По всем присоединенным файлам двоичные данные регистра сведений "Присоединенные файлы" переносятся в том.

 Версия платформы 8.3.5.1486. Сервер 1С x32 Linux Debian.

 Для настройки хранения

  1. Создать общий ресурс на файловом сервере. Например \\FILESERVER\SHARE\

  2. В 1С настроить работу с файлами. Меню Администрирование - Настройки работы с файлами — Включить параметр «Хранить файлы в томах на диске».

    В 

  3. Создать в 1С том для хранения файлов.
    Для сервера 1С под управлением Windows указать путь к общему ресурсу для хранения файлов. Для сервера под управлением Linux можно указать только локальный путь. Для этого нужно создать каталог на сервере 1С, в который будет монтироваться общий ресурс.

    mkdir /mnt/files/.

    И примонтировать к созданному каталогу общий ресурс:

    mount -t cifs -o username=
    DOMAIN\\USER,password=USER_PASSWORD,dir_mode=0777,file_mode=0777 //FILESERVER/SHARE/ /mnt/files/

    Указать для тома локальный путь /
    mnt/files/. Теперь все файлы будут храниться в томе на общем ресурсе

 

В обработке формируется текст запроса по метаданным, содержащим "ПрисоединенныеФайлы" в наименовании и типом хранения в информационной базе. По всем присоединенным файлам двоичные данные регистра сведений "Присоединенные файлы" переносятся в том.

 

Обработка запускалась на конфигурации УТ 11.1.10.94.

 

После выполнения обработки нужно выполнить shrink на MS SQL или vacuum на Postgresql. На файловой версии БД выполнить тестирование и исправление с включенным сжатием таблиц.

 

 

Обновление от 20.12.2019

Добавлена версия обработки для конфигурации УТ 11.4 где был переименован общий модуль "ФайловыеФункцииСлужебный" в "РаботаСФайламиСлужебный". И регистр для хранения присоединенных файлов "ПрисоединенныеФайлы" в "ДвоичныеДанныеФайлов".

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

См. также

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

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

15500 руб.

02.09.2020    201492    1114    410    

1019

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

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

8400 руб.

20.08.2024    35284    203    104    

194

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

Расширение для создания и редактирования печатных форм в системе 1С:Предприятие 8.3. Благодаря конструктору можно значительно снизить затраты времени на разработку печатных форм, повысить качество и прозрачность разработки, а также навести порядок в многообразии корпоративных печатных форм.

22200 руб.

06.10.2023    23818    63    26    

92

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

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

16000 руб.

10.11.2023    16354    70    39    

88

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

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

9360 руб.

17.05.2024    34505    122    53    

165

Инструментарий разработчика WEB-интеграция 1С v8.3 1C v8.2 1C:Бухгалтерия 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Зарплата и Управление Персоналом 3.x Платные (руб)

Инструмент для генерации OpenApi (Swagger) спецификаций на основании файлов конфигураций 1С. Это консольное и десктопное приложение на языке Rust с полноценным редактором кода, содержащим автозамену и подсвечивание ошибок для быстрого и безошибочного написания документирующего комментария.

18000 руб.

22.11.2024    1561    1    0    

8

Инструментарий разработчика Программист 1С v8.3 1C:Бухгалтерия Россия Платные (руб)

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

6000 руб.

07.02.2018    107063    249    100    

313
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Rezident495 19.08.15 13:45 Сейчас в теме
+1 Очень полезная вещь!
2. BudkoT 23.10.15 03:47 Сейчас в теме
Бяда...
{Форма.Форма.Форма(59)}: Метод объекта не обнаружен (ДобавитьФайлВТом)
СведенияОФайле = ФайловыеФункцииСлужебный.ДобавитьФайлВТом(ХранилищеФайла.Получить(), ОбрабатываемыйФайл.ДатаМодификацииУниверсальная,
3. parshin 80 23.10.15 09:44 Сейчас в теме
(2) BudkoT,

Какая версия конфигурации?
4. ben_art 13 21.12.15 15:34 Сейчас в теме
а после переноса ссылки в объектах останутся ?
5. parshin 80 22.12.15 06:45 Сейчас в теме
(4) ben_art,
Ссылки не меняются. Ссылки в объектах на справочник "ПрисоединенныйФайлы", В тома переносится хранилище значения.
6. ben_art 13 22.12.15 11:40 Сейчас в теме
ещё вопрос. где то в базе засели битые или потертые файлы и при переносе выскакивает окошко "невозможно обработать файл "-_trashes"
как этого избежать, может как-то пропускать этот файл или ещё чего нибудь ?
7. parshin 80 23.12.15 09:59 Сейчас в теме
(6) ben_art,
Приведите весь текст ошибки, пожалуйста.
8. ben_art 13 23.12.15 11:51 Сейчас в теме
вот скрин ошибки
Прикрепленные файлы:
9. parshin 80 25.12.15 12:05 Сейчас в теме
(8) ben_art,
Корректно ли настроены права пользователя, от которого запущен сервер 1с или запущена файловая БД , на каталог где расположен том для хранения данных? На каких операционных системах развернут сервер 1с и файловый сервер?
10. ben_art 13 25.12.15 15:11 Сейчас в теме
(9) ДА всё правильно, вернее уже правильно.
файлы побились давно , теперь их не удалить не перенести.
Вот и вопрос как в Вашей обработке можно игнорировать исключения записи ?
11. parshin 80 28.12.15 12:17 Сейчас в теме
(10) ben_art,
В вызываемой функции ДобавитьФайлВТом есть обработка исключения в случае неудачи переноса файла в том. Должны перенестись все небитые файлы. Не могу понять что значит "Битые файлы". Как они появились? Можете написать строку кода где происходит ошибка?
12. zabaluev 466 28.12.15 14:25 Сейчас в теме
Исправил ошибку в данной функции и заработало в 1С Бухгалтерии 3.0.43
Я перенес часть кода в цикле создания запроса.


Процедура ПеренестиФайлыНаСервере(Оценка = Истина)

Запрос = Новый Запрос();
ТекстЗапроса = "ВЫБРАТЬ
| ВложенныйЗапрос.Ссылка
|ИЗ
| (";
Инд = 0;
КолСправочников = Метаданные.Справочники.Количество();
Для Каждого Спр Из Метаданные.Справочники Цикл
Инд = Инд + 1;


Если Найти(Спр.Имя, "ПрисоединенныеФайлы") > 0 Тогда

Если Инд > 1 Тогда
ТекстЗапроса = ТекстЗапроса + "
|
|ОБЪЕДИНИТЬ ВСЕ
|";
КонецЕсли;

ТекстЗапроса = ТекстЗапроса + "ВЫБРАТЬ
| " + Спр.Имя + ".Ссылка КАК Ссылка
|ИЗ
| Справочник." + Спр.Имя + " КАК " + Спр.Имя;
КонецЕсли;
КонецЦикла;
apd1c; ben_art; +2 Ответить
13. ben_art 13 28.12.15 16:55 Сейчас в теме
(12) zabaluev, я уже исправил.
правда пришлось перенести процедуру из общего модуля в обработку
14. Rasdag 164 07.03.16 01:17 Сейчас в теме
Если в наименовании номенклатуры содержатся символы: "/" или "\" - то выдается ошибка
15. Xershi 1539 07.03.16 10:34 Сейчас в теме
(14) rasdag, в файле таких символов не должно быть, вот и ошибка.
16. Rasdag 164 07.03.16 13:41 Сейчас в теме
Это понятно что не должно быть, но по факту как видите бывает. Так же на такой символ ругается - "*". Неплохо бы дописать в код замену таких символов. А так на УТ 11.2 тоже полет нормальный.
17. user689645_gb 18.04.17 09:53 Сейчас в теме
Добрый день! Подскажите ,пожалуйста, как для файловой базы как перенести файлы в тома?
18. user689645_gb 18.04.17 20:17 Сейчас в теме
Добрый день!Купила обработку,сделала перенос файлов на том,все прошло,файлы появились в томе,но размер базы не уменьшился,с чем это может быть связано,пожалуйста,подскажите? Тестирование и исправление со всеми галочками делала несколько раз.База файловая.
19. parshin 80 19.04.17 16:54 Сейчас в теме
(18)Добрый день! Как вариант попробовать выгрузить базу в DT, потом загрузить обратно.
20. user689645_gb 20.04.17 13:32 Сейчас в теме
(19) Добрый день!Не помогло,есть еще какие-то способы?Заранее благодарю.
21. realEvgenius 2 01.08.17 11:01 Сейчас в теме
Интересно, для комплексной 2.2. подойдет?
22. parshin 80 02.08.17 08:33 Сейчас в теме
(21) К сожалению, у меня нет возможности проверить.
23. realEvgenius 2 03.08.17 11:38 Сейчас в теме
(22) Свою задачу я решил, обработку сам написал... Обсуждение тут https://forum.infostart.ru/forum105/topic167472/
Если хотите, могу Вашу проверить на конфе КА2.2. у меня есть копия базы напичканная картинками
24. parshin 80 07.08.17 13:07 Сейчас в теме
(23) А проверьте, было бы неплохо.
25. realEvgenius 2 15.08.17 03:22 Сейчас в теме
(24) Не смог запустить ни в КА2.2, ни в УТ11. Исправил, как написано в (12). Стала открываться, но при запуске ошибка скуль - нет памяти, видимо запрос здоровенный получился или у меня реально база здоровенная ,много слишком мусора
26. parshin 80 15.08.17 13:30 Сейчас в теме
(25) А в каком месте ошибка? При формировании запроса или при переносе файла? Может быть где-то присоединен особо крупный файл?
27. realEvgenius 2 15.08.17 16:44 Сейчас в теме
(26) При выполнении... Доооолго саабражает, вылетает с ошибкой скуль - не хватило памяти... Памяти на тестовом серваке 16 гб, в принципе - не много...
28. goodwill 20 02.03.18 01:24 Сейчас в теме
Спасибо. УТ 11.3.4.59 прошло без ошибок
29. igordynets 92 20.02.19 17:57 Сейчас в теме
Спасибо автору!
Обработка отработала на ура - за счет переноса файлов в тома уменьшили размер базы в 4 раза.
Конфигурация: ERP для Беларуси
30. webandroid 3 19.12.19 09:35 Сейчас в теме
при попытке перенести файлы на УТ 11.4.6 выходит ошибка
{ВнешняяОбработка.ПереносПрисоединенныхФайловВТом.Форма.Форма.Форма(56)}: Поле объекта не обнаружено (ПрисоединенныеФайлы)
МенеджерЗаписи = РегистрыСведений.ПрисоединенныеФайлы.СоздатьМенеджерЗаписи();

в УТ 11 действительно нет РегистрыСведений.ПрисоединенныеФайлы
кто сталкивался?
32. parshin 80 20.12.19 09:46 Сейчас в теме
(30)
(31)
Добавил новую версию для 11.4.
31. valerij1257 19.12.19 17:38 Сейчас в теме
на моей 11.3.4 не получается. вот такая ошибка.
Не подскажите, в чем проблема?
Прикрепленные файлы:
33. parshin 80 23.12.19 10:49 Сейчас в теме
(31)
Добрый день!
Исправил. Проверьте, пожалуйста.
34. DDos76 206 23.03.20 12:41 Сейчас в теме
Обработка полезная, релиз 11.4.11.55 полет нормальный. Только есть замечания. Необходимо ограничивать объем информации, получаемую одним запросом, иначе при большом объеме инфы 1с крашится. В моем случае 20гиг данных в регистре, ограничил пачкой по 500 элементов.
35. Serggray 16 16.04.21 14:09 Сейчас в теме
Добрый день. Делается ли очистка ХранилищаЗначений (самих файлов) после переноса. Уменьшается ли размер базы ?
36. parshin 80 20.04.21 13:21 Сейчас в теме
(35) Добрый день!
Выполняется очистка регистра сведений таки образом:
// очистка двоичных данных записи регистра сведений
НаборЗаписей = РегистрыСведений.ДвоичныеДанныеФайлов.СоздатьНаборЗаписей();
НаборЗаписей.Отбор.Файл.Установить(ОбрабатываемыйФайл);
НаборЗаписей.Записать();
37. Serggray 16 20.04.21 14:15 Сейчас в теме
38. Igor_Gor6 03.02.22 04:24 Сейчас в теме
Добрый день!
Ошибка, как и в (25) - ругается, что запрос слишком "большой" и вылетает, полный текст ошибки:

"Невосстановимая ошибка
Ошибка при выполнении запроса POST к ресурсу /e1cib/logForm:
по причине:
Ошибка СУБД:
Microsoft SQL Server Native Client 11.0: Обработчик запросов исчерпал внутренние ресурсы, и ему не удалось предоставить план запроса. Это редкое событие, которое может происходить только при очень сложных запросах или запросах, которые обращаются к очень большому числу таблиц или секций. Упростите запрос. Если предполагается, что это сообщение получено по ошибке, свяжитесь со службой поддержки для получения дополнительных сведений.
HRESULT=80040E14, SQLSrvr: SQLSTATE=42000, state=1, Severity=10, native=8623, line=1"

Что можно сделать? Может есть возможность предоставить обработку, которая формирует запрос не сразу на все таблицы или вы порекомендуете, что и где можно поменять в коде обработки? Заранее спасибо за ответ.
39. parshin 80 03.02.22 07:25 Сейчас в теме
(38) Добрый день! Предполагаю что проблема в данных.
Запрос собирается по метаданным справочников с наименованием, содержащим "ПрисоединенныеФайлы". Обработка - это просто обертка для методов БПС.
Можно переписать чтобы текст запроса формировался не в цикле по метаданным, а вручную прописать под каждый необходимый для переноса справочник.
Например:
ТекстЗапроса = "ВЫБРАТЬ
| НоменклатураПрисоединенныеФайлы.Ссылка КАК Ссылка
|ИЗ
| Справочник.НоменклатураПрисоединенныеФайлы КАК НоменклатураПрисоединенныеФайлы
|ГДЕ
| НоменклатураПрисоединенныеФайлы.ТипХраненияФайла = ЗНАЧЕНИЕ(Перечисление.ТипыХраненияФайлов.ВИнформационнойБазе)";

Я бы начал с поиска самого жирного справочника и переноса его в том.
Igor_Gor6; +1 Ответить
40. Igor_Gor6 03.02.22 07:42 Сейчас в теме
(39) благодарю за наводку
41. Igor_Gor6 07.02.22 03:52 Сейчас в теме
(39) Добрый день!
К сожалению, в коде плохо понимаю, поступил, как мне кажется - проще: в цикле идёт поиск по всем справочникам, в название которых входит "Присоединенныефайлы" - в итоге я там же и добавил в название, например - "ГИСМПрисоединенныефайлы" - всё ок, находит файлы по данному справочнику, отрабатывает корректно. Однако при попытке перенести файлы выдаёт ошибку "Метод объекта не обнаружен"
Можете подсказать в чем причина?
Прикрепленные файлы:
42. modern-tomsk 14.08.22 10:07 Сейчас в теме
добрый день! могу обратиться именно к Вам для доработки это обработки? в личные сообщения почему-то не удается написать
43. parshin 80 15.08.22 12:28 Сейчас в теме
(42) Здравствуйте! Можете.
44. modern-tomsk 16.08.22 08:58 Сейчас в теме
(43)
написал в личные сообщения
Оставьте свое сообщение