1с ошибка субд превышен максимально допустимый размер внутреннего файла

Содержание:

1.       Причины ошибки Превышен размер внутреннего файла

2.       Анализ и возможные варианты решения ошибки Превышен размер внутреннего файла

3.       Проверка настроек подсистем

4.       Способы анализа размеров таблиц базы данных

5.       Варианты решения ошибки Превышен размер внутреннего файла

Ошибка СУБД «Превышен максимально допустимый размер внутреннего файла 1Cv8.1CD» характерная для файловых баз данных 1С, имеющих относительно большой объем данных. В этой статье будут рассмотрены возможные причины возникновения ошибки Превышен размер внутреннего файла в 1С,способы и инструменты для ее исправления.  

1.     Причины ошибки Превышен размер внутреннего файла

Появление ошибки Превышен допустимый размер внутреннего файла возможно как в пользовательском режиме работы (рис. 1), в момент записи данных в базу, так и при попытке загрузить архив базы из dt-файла(рис.2). В обоих случаях в тексте ошибки фигурирует файл 1Cv8.1CD, но причина ошибки не в размере самого файла, а в размерах составляющих его структуру внутренних файлов.

Рис.1. Ошибка в пользовательском режиме работы

Рис.2. Ошибка при загрузке базы из dt-файла

Как Вы можете видеть на выше представленных скринах, размеры файла 1Cv8.1CD в момент возникновения ошибки Превышен максимальный размер внутреннего файла существенно разнятся, т.е. определенного лимита на его объем нет. Этим так же можно объяснить возможность работы баз, размер файла которых может значительно превышать 10 Гбайт. Ограничения есть на размер внутренних файлов1Cv8.1CD. Ознакомится с ними можно в приведенной ниже выдержке из приложения «Особенности работы с различными СУБД» к документации1С:Предприятие. Руководство разработчика.

Структура файловой баз данных

Для понимания структуры файловой базы данных важно знать, что файл базы данных 1Cv8.1CD состоит из множества внутренних файлов. Каждой таблице базы данных соответствует максимум четыре внутренних файла.

Размер каждого из внутренних файлов ограничен:

● для формата версии 8.2.14 ‑ 4 Гигабайта.

● для формата версии 8.3.8 с размером страницы 4 096 байт ‑ 4 Гигабайта.

● для формата версии 8.3.8 с размером страницы 8 192, 16 384, 32 768 и 65 536 байт ‑ 6 Гбайт.  

2.     Анализ и возможные варианты решения ошибки Превышен размер внутреннего файла

Утилита CNVDBFL.EXE 

Начиная с версии 8.3.9в новых информационных базах по умолчанию установлен реализованный в версии 8.3.8 оптимизированный формат файловой СУБД. Проверить какая версия формата используется в вашей базе, можно с помощью утилиты командной строки CNVDBFL.EXE, которая включается в комплект поставки технологической платформы «1С:Предприятие» начиная с версии 8.3.8 и расположена в каталоге «bin» установленной версии(например C:ProgramFiles1cv88.3.18.1334bin).

Рис. 3 Получить информацию о файле 1Cv8.1CD

Выполните команду: C:< путь установки 1С:Предприятие>CNVDBFL.EXE-i<путь к 1CV8.1CD>

Утилита выведет информацию о версии формата файла и размере страницы. Если версия формата ниже8.3.8 или размер страницы равен 4096 байта, то самое простое временное решение, позволяющее быстро восстановить работоспособность, увеличив ограничение на размер внутренних файлов с 4 Гбайт до 6Гбайт – выгрузить информационную базу в dt-файлдля последующей его загрузки в созданную в новой папке информационную базу, либо конвертация в формат 8.3.8 со страницей по умолчанию:

cnvdbfl -c -f 8.3.8 <путь к 1CV8.1CD>

ВНИМАНИЕ! Перед выполнением любых операций с информационной базой сделайте резервную копию.  

3.     Проверка настроек подсистем

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

Настройки подсистемы Работа с файлами

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

Рис.4 Настройки работы с файлами

Настройки хранения истории изменений

Проведите аудит настроек подсистемы хранения истории изменений. Особое внимание следует уделить часто изменяемым объектам с бессрочным хранением версии, т.к. каждая версия – это новая отдельная запись, занимающая место в специальной таблице базы дынных. И точно не стоит включать «на всякий случай» бессрочное сохранение версий, создаваемых при записи, для всех объектов.

    


Рис.5 Настройки хранения истории изменений

Удаление помеченных объектов

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

Рис.6 Настройка расписания удаления помеченных объектов  

4.     Способы анализа размеров таблиц базы данных

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

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

Загрузка dt-файла в клиент-серверную базу данных

Разберем на примере файловой СУБДMSSQL.

В SQL ServerManagementStudio выберем в обозревателе объектов исследуемую базу и сформируем стандартный отчет «Использование дисковой памяти таблицами». Включив сортировку по убыванию значения в колонке «Данные», мы увидим самые большие таблицы. В моем случае явный лидер -«dbo._InfoRg10162»

 

Рис. 7 Анализ размера таблиц базы данныхвSQLServerManagementStudio

Далее нам потребуется определить какие данных хранятся в этой таблице. В этом нам поможет метод глобального контекста ПолучитьСтруктуруХраненияБазыДанных(). Вызвать данный метод можно установив точку остановки в любой процедуре, выполняемой в контексте сервера, например в процедуре ПриСозданииНаСервере формы внешней обработки. Указав в табло выражение ПолучитьСтруктуруХраненияБазыДанных(), мы получим таблицу значений с описаниями структуры таблиц, индексов и полей базы данных. Посмотреть ее можно нажав «F2»,либо выполнив команду контекстного меню «Показать значения в отдельном окне». В открывшемся окне выполняем поиск значения «InfoRg10162» в колонке ИмяТаблицыХранения и определяем по колонкам ИмяТаблицы или Метаданные имя, соответствующее объекту метаданных конфигурации — «РегистрСведений.ДвоичныеДанныеФайлов»

Рис. 8 Просмотр структуры хранения базы данных

Стоит отметить, что данный метод требует серверной лицензии 1С.

На момент написания статьи действует акция: антикризисные льготные поставки «1С:Предприятия 8» для разработчиков.

В качестве СУБД для разработки и тестирования удобно использовать следующие версии:

SQL Server 2019 Express является бесплатным выпуском SQL Server, который идеально подходит для разработки приложений для использования на настольных компьютерах, веб-серверах и других небольших серверах.

SQL Server 2019 Developer — это бесплатный выпуск с полным набором функций, лицензируемый для использования в качестве базы данных для разработки и тестирования и не предназначенный для применения в рабочей среде.

Использование сторонних программ для анализа файла базы

Для определения размеров таблиц базы данных, можно воспользоваться программой для просмотра файлов базы 1Сv8.1CD. Tool_1CD позволяет увидеть структуру БД 1С и узнать размер внутренних таблиц. Tool_1CDверсии 0.3.0, поддерживает работу только с базами в формате не выше 8.2.14.

 

Рис. 9 Tool_1CDверсии 0.3.0

Для анализа базы в формате 8.3.8.0 потребуется конвертация копии базы с помощью утилиты cnvdbfl в версию, совместимую с 8.2 (cnvdbfl -c -f -8.2.14 «путь к базе»)

Tool_1CD версии 0.4.0поддерживает работу с базами версии формата 8.3.8.0 и не требует дополнительных операций с базой.

Рис. 10 Tool_1CDверсии 0.4.0

Определив имя «проблемной» таблицы, далее поступаем аналогично первомупримеру(Рис. 8).Выполняем поиск значения «InfoRg10162″в колонке ИмяТаблицыХранениятаблицы, полученной методом ПолучитьСтруктуруХраненияБазыДанных()и определяем по колонкам ИмяТаблицы или Метаданные имя соответствующее объекту метаданных конфигурации.

Подсистема «Инструменты разработчика» 1С 8

На практике меня часто выручает подсистема «Инструменты разработчика» 1С 8

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

В рамках рассматриваемой в статье ошибки, нам будет интересна обработка «Структура хранения БД», в которой есть опция получения размеров таблиц и индексов для файловой СУБД.

Рис. 11 Запуск обработки Структура хранения БД в толстом клиенте

Почти все обработки входящие в подсистему выполнены на обычных формах и потому работают только в толстом клиенте и обычном приложении.

Рис. 12 Выбор варианта запуска подсистемы

Рис. 13 Запуск обработки Структура хранения БД в обычном приложении

По умолчанию опция «Показывать размеры» выключена. Включим этот флаг и выполним сортировку по убыванию в колонке «Размер общий»

Рис. 14 Анализ данных в обработке Структура хранения БД

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

Обратите внимание, опция «Показывать размеры» работает только в 32-битныхприложениях

Рис. 15 Настройка разрядности клиента  

5.     Варианты решения ошибки Превышен размер внутреннего файла

Выбор способа решения ошибки Превышен размер внутреннего файла зависит от результатов анализа и сводится к двум вариантам:

·         Уменьшение размера базы данных;

·         Переход на клиент-серверный вариант работы;

Если анализ выявил таблицы, занимающие «львиную долю» от общего размера внутреннего файла 1Cv8.1CD, то в первую очередь надо разобраться с ними. Как правило это объекты конфигурации, имеющие реквизиты с типом значения Хранилище Значения, в которых хранятся связанные файлы, версии объектов, вложения писем и т.д.

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

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

Взаимодействие между клиентским приложением и файловой СУБД осуществляет кластер серверов «1С:Предприятия 8».

Так же клиент-серверный вариант работы будет решением проблемы при загрузке архива базы из dt-файла

Рис. 16 Загрузка из dt-файла заведомо большой ИБ

Специалист компании «Кодерлайн»

Александр Бачурин

Вопрос  

При попытке отправки  из 1С:Бухгалтерии  ответа на требование ИФНС появилась ошибка «Превышен  максимально допустимый  размер внутреннего файла…», хотя общий размер файлов  вложений в подготовленном ответе не превышает установленного лимита.

Ответ  

Причиной ошибки является то, что в файловой информационной  базе 1С все данные хранятся в одном файле 1Cv8.1CD, который имеет ограничения по объему и структуре.

Как исправить ситуацию?

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

Итак, для уменьшения размера базы можно выполнить следующие действия:

  1. Настроить  хранение внешних файлов в отдельном хранилище вне программы 1С с сохранением доступа к таким файлам из 1С.

  2. Создать архив файлов 1С-Отчетности  без доступа к нему из 1С.

Рассмотрим подробнее оба способа.

Настроить хранение файлов  во внешнем хранилище с сохранением доступа к ним из 1С.  

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

Для включения настройки перейдите:  Администрирование – Настройки работы с файлами – Включить флаг «Хранить файлы в томах на диске» — Тома хранения файлов — Создать.

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

По завершению  настройки тома для внешних файлов искомая ошибка с превышением размера файла базы разрешится. Можно отправлять ответ на требование.

Помимо настройки хранения в отдельном каталоге  новых поступающих внешних  файлов,  можно перенести все  старые файлы 1С-Отчетности во внешний каталог с сохранением к нему доступа из базы 1С. Для этого  необходимо выполнить  регламентное задание «Перенос сообщений 1С-Отчетности в присоединенные файлы» (Администрирование – Обслуживание – Регламентные и фоновые задания – Выбрать задание из списка  — Выполнить). За один запуск задание переносит только 10 файлов. Можно  настроить расписание запусков регламентного задания в фоновом режиме, помня, что регламентные задания в файловой информационной базе  выполняются только тогда, когда информационная база запущена в  режиме 1С:Предприятие.

После переноса архивов  необходимо выполнить сжатие и реструктуризацию  таблиц информационной базы  режиме «Конфигуратор» (см. ниже).

Описанный  вариант  не подходит в случае переноса  базы 1С за пределы локальной сети.  

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

Создать архив файлов 1С-Отчетности  без доступа к нему из 1С.

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

Для подключения обработки  в 1С Бухгалтерии 3.0 перейдите Администрирование – Печатные формы, отчёты и обработки – Дополнительные отчеты и обработки Включите соответствующий флаг и перейдите по одноименной ссылке.

Нажмите Добавить из файла,   согласитесь с предупреждением безопасности.

Запустите обработку  «Создание архива документооборота»

После переноса файлов в тома необходимо выполнить реструктуризацию и сжатие таблиц информационной базы в режиме Конфигуратор  для уменьшения физического размера файла  1Cv8.1CD (Администрирование – Тестирование и исправление —  Включить флаги — Выполнить). Перед тестированием необходимо сохранить резервную копию базы.

После сжатия и реструктуризации база уменьшится, что позволит отправить ответ на требование.  
Дополнительно  смотрите статью на сайте ИТС 
https://its.1c.ru/db/elreps#content:59:1

   ALEX7519

17.02.22 — 08:55

Тут да днях случилась такая штука — перестала работать синхронизация Бухгалтерии 30 с ЗУП 30 , т.е из зупа выгрузка проходит, в бух не грузится. Посмотрел по журналу пишет в ошибках Ошибка СУБД Превышен максимально допустимый размер внутреннего файла 1Cv8.1CD. ( синхронизация настроена не через файл а обращением к базе )

посмотрел размер бух базы — около 20 гигов. (базы файловые ).

я так понимаю дело в этом (хотя сама база работает без ошибок, не совсем ясно почему толькро при синхронизации ??? )

надо уменьшать размер базы ?

правильно ли я понимаю последовательность действии : ??

1. Прогнать cd c помощью chdbfl.exe с галкой испралять

2. В конфигуратере через тестирование и исправление с галками сжатие и реструкторизация

если не уменьшится перенести файлы в тома на диске ?

(тут тоже не совсем понял, в настройках работы с файлами надо поставить Хранить файлы «в томах на диске» или «в инф базе и в томах на диске» ? , потом создаю том и через гиперссылку «перенос файло» переношу туда файлы ? после этого они будут открываться у пользователей ?)

посмотрел с помощью CNVDBFL.EXE -i G:1Cv8.1CD структуру файла

формат : 8.3.8

размер страницы : 8192 — это норм ?

   Волшебник

Модератор

1 — 17.02.22 — 08:58

Надо перейти на серверную базу

   Chai Nic

2 — 17.02.22 — 09:04

С учетом «размер страницы : 8192» у вас уже был использован «последний шанс» увеличения размера внутреннего файла с 4 до 6 Гб. Это прибитое гвоздями ограничение, при использовании файловой базы с увеличенным размером страницы. Чтобы покупали серверную лицензию. Вот и покупайте..

   ALEX7519

3 — 17.02.22 — 09:15

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

разве она может влиять на синхронизацию с зуп ?  т.е. уменьшу я сдшник за счет них, но не факт что это поможет ? да?

   Guk

4 — 17.02.22 — 09:20

(3) да…

   Winnie Buh

5 — 17.02.22 — 09:27

(0) 100% вариант — это только переход на SQL

все остальные 50/50

   mistеr

6 — 17.02.22 — 09:33

(1) Или почистить лишнее

   mistеr

7 — 17.02.22 — 09:35

(3) Посмотри с помощью Tool1CD какой файл подошел к 6 Гб. И можно ли его уменьшить.

   ALEX7519

8 — 17.02.22 — 09:54

а как узнать что это за таблица, через тулс1с посмотрел вот эта к примеру : INFORG24411 — что это ?

   Ёпрст

9 — 17.02.22 — 09:55

(8) табличка регистра сведения

   Ёпрст

10 — 17.02.22 — 09:55

   Ёпрст

11 — 17.02.22 — 09:56

Что за рс, можео посмотреть через получитьструктурутаблицхранения блатбла бла, в сп найдешь метод, ну или поделками, коих как грязи на нимфостарте

   mistеr

12 — 17.02.22 — 09:57

(8) Инструменты Разработчика, Структура хранения БД.

   Winnie Buh

13 — 17.02.22 — 10:45

Сервер МИНИ до 5-ти сеансов — 14400 руб.

   ALEX7519

14 — 17.02.22 — 10:56

посмотрел самая большая таблица «РегистрСведений.ВерсииОбъектов»

что это за ? его можно почистить ? 6.5 гигов занял

   rozer76

15 — 17.02.22 — 11:00

(14) конечно, это версионирование БСП. Хотя давно в платформе это нативно есть

   Ёпрст

16 — 17.02.22 — 11:03

(14) да. Просто грохаешь все записи в нём и привет. Оно тебе не нужно.

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

   ALEX7519

17 — 17.02.22 — 11:09

по инету покопался народ пишет обработки оставляет только последние записи и т.п. … это для чего то или можно все сразу грохнуть ?

   Ёпрст

18 — 17.02.22 — 11:10

(17) ну. кто-то видать хоть иногда смотрит версии объектов, и оставляют последние, для истории.

   mistеr

19 — 17.02.22 — 11:11

(17) Если до сих пор не понадобилось, значит можно грохнуть. Если вдруг понадобится, есть же бэкапы. (Они же есть, да?)

   Ёпрст

20 — 17.02.22 — 11:16

И..лучше насовсем версионирование отключи в константах. Быстрее будут доки проводится/записываться.

Один хрен, не используете

   Dmitrii

21 — 17.02.22 — 11:31

Забавно. А с чего все взяли, что версионирование не используется? Может там бухи регулярно проверяют — кто, что и когда поменял в базе.

Сначала надо у пользователей спросить. Если опрос покажет, что никто не знает о чём идёт речь (такое вполне возможно), то можно смело грохать.

Но если выяснится, что всё таки кому-то нужно версионирование, то придётся настроить регулярную очистку старых версий объектов. И возможно отключить версионирование у некоторых объектов, оставив только у самых важных.

   ALEX7519

22 — 17.02.22 — 11:39

В базе в администрировании не стоит галки хранить историю изменений,

залез в этот регистр и обнаружил, что в нем записываются данные только по документу «Отражение зарплаты в бухучете», причем каждый день по несколько записей

( видимо так как настроена автоматическая синхронизация с зуп то он при каждом обращении к базе зуп туда фигачит записи )

т.е. если я его почищу он при очередной синхронизации не перезапишет мне в бух базе эти документы по отражению зарплаты с начала работы

   Обработка

23 — 17.02.22 — 11:46

(22) Очень странно что именно обмен влияет на версии.

Хотя ад у меня те ведь при обмене если изменился объектов автоматом регит.

Просто надо выяснить нужно это кому или нет.

И удалить. На крайняк можно оставить последний месяц или два.

Я недавно у себя чистил версии и база сильно уменьшился.

   Ёпрст

24 — 17.02.22 — 11:52

(22) это не история изменений, это старый механизм версионирование

   Жан Пердежон

25 — 17.02.22 — 11:53

(0)

https://v8.1c.ru/price/

1С:Предприятие 8.3. Сервер МИНИ на 5 подключений

14 400 руб.

   ALEX7519

26 — 17.02.22 — 12:03

(24) ну т.е. если почикать вот так

НаборЗаписей = РегистрыСведений.ВерсииОбъектов.СоздатьНаборЗаписей();

НаборЗаписей.Записать();    

то ничего плохого не случится ? :))

   ALEX7519

27 — 17.02.22 — 12:05

(25) 1С:Предприятие 8.3. Сервер МИНИ на 5 подключений

14 400 руб.

это дешовая версия для перехода на SQL ? еще что-ниб локупать надо будет ?

   Dmitrii

28 — 17.02.22 — 12:05

(22) >> В базе в администрировании не стоит галки хранить историю изменений.

Тогда включи эту галку. Перейди в диалог настройки. оставь у всех объектов «Когда сохранять версии» = «Никогда». У документа «Отражение зарплаты в бухучете» установи «Когда сохранять версии» = «При проведении» и «Срок хранения версий» = «Неделя».

Внизу формы есть галочка «Автоматически удалять устаревшие версии». Установи её и настрой расписание этого регламента. Например, раз в неделю. При первом выполнении это регламент заодно удалит все старые имеющиеся записи.

   Dmitrii

29 — 17.02.22 — 12:11

(27) >> это дешёвая версия для перехода на SQL?

В некотором роде. Если у вас действительно не больше пяти одновременно работающих с 1С пользователей. Больше 5 подключений сервер МИНИ сделать не даст.

>> еще что-нибудь докупать надо будет?

СУБД. Но есть бесплатные версии. Например.

MS-SQL Express (имеет ряд ограничений на размер базы, объём используемой памяти, что-то ещё — подробнее надо смотреть на сайте MS). Для вас должен подойти.

PostgreSQL. Полностью бесплатен. Есть версии для Windows и Linuх.

   Ёпрст

30 — 17.02.22 — 12:12

(26) делай.

   Повелитель

31 — 17.02.22 — 12:27

(29) MS-SQL Express (имеет ряд ограничений на размер базы, объём используемой памяти, что-то ещё — подробнее надо смотреть на сайте MS). Для вас должен подойти.

Там ограничение на 2 Гб база )))

Бесплатная только PostgreSQL будет

   1Сергей

32 — 17.02.22 — 12:32

(31) 2 гб? Ничо не путаете? Вроде, 10 было

   acht

33 — 17.02.22 — 12:32

   Winnie Buh

34 — 17.02.22 — 12:33

(31) у MS SQL Express ограничение на размер базы до 10Гб, но ТС в любом случае не подойдет,

PostgreSQL или платная MS SQL

   Dmitrii

35 — 17.02.22 — 13:02

(34) >> у MS SQL Express ограничение на размер базы до 10Гб.

Странно. Действительно только 10Гб. Мне почему-т оказалось, что больше.

Ну значит только PostgreSQL.

   ALEX7519

36 — 17.02.22 — 15:55

А ЕЩЕ ВОПРОС :

НаборЗаписей = РегистрыСведений.ВерсииОбъектов.СоздатьНаборЗаписей();

НаборЗаписей.Записать();    не сработало, вернее работало работало потом выдало что не хватает памяти и вылетело.

переписал вот так, но тоже медленно работает ( удаляю по частям ): может как-ниб по другому можно написать чтобы быстрее работало ?

ТЗ = Новый ТаблицаЗначений;

    ТЗ.Колонки.Добавить(«Док»);

    
    Запрос = Новый Запрос;

    Запрос.Текст = «ВЫБРАТЬ

    |    ВерсииОбъектов.Объект КАК Объект

    |ИЗ

    |    РегистрСведений.ВерсииОбъектов КАК ВерсииОбъектов

    |ГДЕ

    |    ВерсииОбъектов.ДатаВерсии МЕЖДУ &Дата1 И &Дата2

    |

    |СГРУППИРОВАТЬ ПО

    |    ВерсииОбъектов.Объект»;

    
    Запрос.УстановитьПараметр(«Дата1»,ДатаН );

    Запрос.УстановитьПараметр(«Дата2»,ДатаК );

    
    Результат = Запрос.Выполнить();

    Выборка = Результат.Выбрать();

    
    Пока Выборка.Следующий() Цикл

    
        стр = ТЗ.Добавить();

        стр.Док = Выборка.объект;

    
    КонецЦикла;

    
    ТЗ.Свернуть(«Док»);

    
    для Каждого стр из ТЗ Цикл

        
        Если  стр.Док.Метаданные().Имя = «ОтражениеЗарплатыВБухучете» или стр.Док.Метаданные().Имя = «ВедомостьНаВыплатуЗарплаты»  Тогда

        
        НаборЗаписей = РегистрыСведений.ВерсииОбъектов.СоздатьНаборЗаписей();

        НаборЗаписей.Отбор.Объект.Установить(стр.Док);

        НаборЗаписей.Записать();

        
        КонецЕсли;

        
    КонецЦикла;

   Ёпрст

37 — 17.02.22 — 15:56

(36) через менеджер можно удалять еще

   Ёпрст

38 — 17.02.22 — 15:56

чуток удалить, и потом записать пустой набор

  

johnnik

39 — 17.02.22 — 17:26

Дважды в «карьере» сталкивался с подобной ошибкой и оба раза причиной был распухший регистр сведений «Замеры производительности». Очищается легко (есть обработка на инфостарте)

Описание ошибки:
В файловой базе при сохранении элемента справочника «Хранилище дополнительной информации»:
Ошибка СУБД:
Превышен максимально допустимый размер внутреннего файла ‘D:1C baseTR/1Cv8.1CD’
по причине:
Превышен максимально допустимый размер внутреннего файла ‘D:1C baseTR/1Cv8.1CD’

Найденные решения:

1C 8 ошибка при сохранении элемента справочника Ошибка СУБД: Превышен максимально допустимый размер внутреннего файла

1C 8 ошибка при сохранении в базе, превышен максимально допустимый размер внутреннего файла 1Cv8.1CD

Видео примера ошибки:

Анатомия ошибки становится ясна, если знать о важном ограничении, которое накладывается на файловую базу — ограничение максимального размера любой из внутренних таблиц не больше 4 Гб. По сути по-простому, таблица — это либо все элементы одного какого-либо справочника или документы какого-то одного вида. В приведенном примере ошибки такой таблицей, справочником, является справочник «Хранилище дополнительной информации», в котором в базе 1С: Управление торговлей 8 ред. 10.3 хранятся файлы и изображения, прикрепляемые к другим справочникам или документам. Т.е. по логике в Вашем случае, в Вашей базе, оцениваете — при записи какого справочника или документа возникает ошибка «Ошибка СУБД: Превышен максимально допустимый размер внутреннего файла ‘1Cv8.1CD'».

Вторым распространенным примером может послужить переполнение в таблице, связанной с документами «Электронное письмо», которые в базах служат некоторым аналогом электронного письма, они хранятся со всеми вложениями (файлами) в базе. Поэтому в частном случае может потребоваться провести работу, которая дальше будет описана с этим видом документов.

Т.е. характер ошибки уже подсказывает нам о том, что нужно удалить часть данных справочника или документов, чтобы высвободить место в базе. Для этого необходимо пометить на удаление те элементы, которые уже не актуальны, выполнить удаление с помощью обработки «Удаление помеченных объектов» и закрепить результат операцией «Тестирование и исправление» в базе данных. А теперь более подробно по шагам рассмотрим пример.

Перед началом работ создайте архивную копию базы.

С помощью обработки «Групповая обработка справочников и документов» в текущем примере можно отобрать все элементы справочника «Хранилище дополнительной информации» по объектам — элементам справочника «Номенклатура», содержащихся в группе (папке) с уже неактуальными элементами.

1С 8 как исправить ошибку Превышен максимально допустимый размер внутреннего файла '1Cv8.1CD'

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

1С 8 групповая пометка на удаление в базе с управляемым интерфейсом

В разделе «Администрирование и НСИ» по ссылке «Обслуживание» находим в группе «Корректировка данных» — «Групповое изменение реквизитов». Необходимо установить флажок настройки «Специальные возможности» «Показывать служебные реквизиты» по кнопке «Дополнительные параметры…». Тогда станет возможным установка служебного реквизита «Пометка удаления» в значение «Да».

1C 8 как устранить, избавиться от ошибки Превышен максимально допустимый размер внутреннего файла 1Cv8.1CD

Это было небольшое отвлечение для примера в базе с управляемым интерфейсом, продолжим рассматривать пример для текущей ситуации.

После нажатия кнопки «Отобрать» для списка ссылок выбирается «Действие» — «Изменить: [Пометка удаления]» и «Установить» в поле справа. Нажимается кнопка «Выполнить».

1С 8 как устранить ошибку СУБД Превышен максимально допустимый размер внутреннего файла

Процесс установки пометки на удаление будет сопровождаться индикатором и сообщениями:

1С 8 при сохранении, записи Ошибка СУБД: Превышен максимально допустимый размер внутреннего файла

После того, как этот процесс закончится, запускаем штатную процедуру «Удаление помеченных объектов», запускаем удаление.

1С 8 как избавиться, вылечить Ошибка СУБД: Превышен максимально допустимый размер внутреннего файла

После удаления выполняем процедуру «Тестирование и исправление …» в базе. В списке «Проверки и режимы» можно оставить флажки для режимов «Реиндексация таблиц информационной базы», «Пересчет итогов», «Сжатие таблиц информационной базы», «Реструктуризация таблиц информационной базы». Но, если установите все флажки для режимов, то ошибки не будет — выполнение будет происходить дольше.

Оцените, помогло ли Вам предоставленное описание решения ошибки?




© www.azhur-c.ru 2014-2020. Все права защищены. Использование текстов и изображений с данной страницы без письменного разрешения владельца запрещено. При использовании материалов с данной страницы обязательно указание ссылки на данную страницу.

15-10-2020

Журавлев А.С.
(Сайт azhur-c.ru)

Однажды вылетело: «Ошибка СУБД. Превышен максимально допустимый размер внутреннего файла …/1CV8.CD»

И Все! Данных больше ввести никаких нельзя. Размер Файла 1Cv8.1CD 4,5 ГБ.

Ответ: Про ограничения в файловой версии можно прочитать на последнем ИТС. Действительно — 4 Гб.

Решение: Переходить на MS SQL. В серверном варианте размер базы ограничен возможностями MS SQL сервера.


Дополнение от Andy1981:

Столкнулся с проблемой только сейчас. До этого постоянно работал на серваках, даже тестовая база была развернута на собственном скуле, который крутился у меня локально :-)

В общем-то, решение тривиально, переход на клиент-серверный вариант, и всех делов. Но! Меня задело за живое. Даже если решение очевидно, нужно сначала обосновать его, а не слепо следовать предложенному варианту. Прежде чем выносить вердикт, относительно того, как нужно поступить, исполнил элементарный скрипт на SQL, получил табличку в виде ИмяТаблицыБД|РазмерТаблицы. Прекрасно, но это позволит лишь определить, в каком классе объектов метаданных проблема. Далее, используя Enterprise Integrator получил имя справочника (в моем случае), имеющего проблемный размер. Далее дело за малым — всего-то и делов — определиться, каким образом можно оптимизировать хранение данных? В моем случае ответ оказался практически очевиден. Оптимизировать можно и нужно, и использование сервера БД нецелесообразно. Вполне возможно, что таблица распухает вполне обоснованно, тогда переход на SQL (например), является неизбежным.

Скрипт для вычисления объемов таблиц БД:

Код SQL

 USE MyInfoBase --Имя БД

DECLARE @tbl TABLE (
name nvarchar(128),
[rows] char(11),
reserved varchar(18),
data varchar(18),
index_size varchar(18),
unused varchar(18)
)

DECLARE @name sysname

DECLARE CUR CURSOR FOR SELECT name FROM sys.tables
OPEN CUR
FETCH NEXT FROM CUR INTO @name
WHILE @@FETCH_STATUS = 0 BEGIN
INSERT @tbl EXEC sp_spaceused @name
FETCH NEXT FROM CUR INTO @name
END
CLOSE CUR 
DEALLOCATE CUR

SELECT
name,
[rows],
reserved,
data,
index_size,
unused,
reserved_kb
FROM
(SELECT  
name,
[rows],
reserved,
data,
index_size,
unused,
CONVERT(bigint, REPLACE(reserved, ' KB', '')) AS reserved_kb
FROM @tbl
) Q
ORDER BY
reserved_kb DESC
COMPUTE SUM(reserved_kb)

  • 1с ошибка создания файла для конвертора
  • 1с ошибка создания файла dbf
  • 1с ошибка создания источника доступных настроек компоновки данных undefined
  • 1с ошибка создания защищенной обработки
  • 1с ошибка совместного доступа к файлу процесс не может получить доступ к файлу