Ошибка "The index entry of length X bytes for the index ' ... ' exceeds the maximum length of 900 bytes."

27.11.15

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

Возможно, вы уже столкнулись с ошибкой "The index entry of length X bytes for the index ' ... ' exceeds the maximum length of 900 bytes."
При записи в регистр больших значений 1С легко вылетает в дамп.
Давайте детально рассмотрим, что это и как этого избежать!

Справка.

Итак, что же нам говорит microsoft: https://msdn.microsoft.com/en-us/library/ms191241(v=sql.105).aspx.

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

Как это случилось?

Давайте смоделируем эту ошибку:

Создаем регистр с несколькими измерениями.

Тип данных измерения: строка.

Длина измерения чем больше, тем хуже: max 1024 символа.

И вот у вас несколько измерений в 1024 символа. Ничего не предвещает беды, пока вы не начали по полной эти измерения использовать. В один момент у вас попадается запись, в которой должна быть большая строка, и в этот момент и вылетит ошибка.

Ресурсы регистра хоть и со свойством не индексировать, но индексы таблиц создаются неявным образом при создании объектов конфигурации системой 1С:Предприятие 8. Справка: http://its.1c.ru/db/metod8dev/content/1590/hdoc

Вот и попали мы на исключение!

Вывод.

Хоть 1С и позволяет в регистрах указывать длину большую, чем может обработать MS SQL, но не стоит пренебрегать ограничениями!

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

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

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

См. также

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

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

24900 руб.

20.08.2024    68728    365    164    

315

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

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

17000 руб.

10.11.2023    25341    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    22801    80    10    

113

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

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

14640 руб.

29.04.2020    50230    136    162    

92

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

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

6000 руб.

15.04.2026    1728    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    46025    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    1271    1    0    

4
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Danil.Potapov 173 26.10.15 20:01 Сейчас в теме
проблема не в полнотекстовом поиске а в кластерном индексе по всем измерениям (который создается на уровне платформы).
alest; dmpas; +2 Ответить
2. Xershi 1553 26.10.15 20:04 Сейчас в теме
(1) Dpotapov, т.е. ты хочешь сказать, что полнотекстовый поиск на индекс никак не влияет?
3. ojiojiowka 26.10.15 21:23 Сейчас в теме
(2) да, именно так. В 1С это отдельный механизм, никак не связанный с полнотекстовым поиском СУБД
4. Xershi 1553 27.10.15 09:37 Сейчас в теме
(3) ojiojiowka, а где это можно прочесть? Добавлю в статью.
17. AlexO 136 06.03.18 12:23 Сейчас в теме
(4) потому что поиск осуществляет 1С-сервер, а не СУБД.
1С для этого специально создает свои ключи в таблицах. Можете сами проследить - при поиске сначала выборка из БД, а потом 1С-сервер "шуршит" сам, иногда - длительное время, "ковыряясь" в полученных данных.
1С вообще мало использует возможности СУБД - хорошо, если процентов на 10 всех возможностей.
А так да, было бы здорово, если бы и поиск был от СУБД, и использование хинтов, и "окна" в выбоках... мечты-мечты ))
10. Silenser 621 28.10.15 11:26 Сейчас в теме
(3) ojiojiowka, Если мне не изменяет память, даже полнотекстровый поиск в SQL тоже отдельный механизм, не завязаный с индексами. В запросах с таким поиском используется специальное ключевое слово CONTAINS. И поиск ведется по специальному каталогу полнотекстового индекса.
5. AlX0id 27.10.15 12:00 Сейчас в теме
Неплохо бы еще уточнить платформу.. В какой-то из свежих запихнули (или обещали) в хэш не помещающиеся индексы.
6. Xershi 1553 27.10.15 12:40 Сейчас в теме
(5) AlX0id, так тут речь об ограничениях MS SQL. У нас стоит 2012. Или вы про 1с7 или 1с8? Думаю, в семерке будет такая же ошибка. Но не тестировал.
7. AlX0id 27.10.15 13:04 Сейчас в теме
(6)
Да, об ограничениях SQL. Но в новых версиях платформы 1С некоторые из них учитываются, как это ни странно звучит.
И само собой я про 8-ку.
8. Xershi 1553 27.10.15 13:08 Сейчас в теме
(7) AlX0id, 8.3.6 я даже не ставил из-за ее глючности. А вот на 1С:Предприятие 8.3 (8.3.5.1248) такой фишки еще нет.
9. Danil.Potapov 173 28.10.15 00:13 Сейчас в теме
(5) хеш там есть всегда, когда более одного измерения. хеш используется более быстрого поиска уникальных записей.
11. AlX0id 28.10.15 11:58 Сейчас в теме
(9) Dpotapov,
Я вот об этом:
Поле "ХэшИзмерений" добавляется, количество других полей больше 15.

Но это для регистра бухгалтерии ток.. И это не тот случай, который описан в статье, хотя смежный.
12. Xershi 1553 28.10.15 12:09 Сейчас в теме
Ребята, лучше ссылки на источники дайте. А то гадать на домыслах не лучшая идея.
13. AlX0id 29.10.15 20:38 Сейчас в теме
(12)
Я исхожу из статьи с ИТС про индексы. Недавно обновлена, кстати.
14. Xershi 1553 30.10.15 08:59 Сейчас в теме
(13) AlX0id, благодарю за информацию!
15. mirrokus 06.03.18 10:33 Сейчас в теме
Народ как найти индекс по имени, какой-то idx8 не могу найти с БД. нет там таких имен
16. Xershi 1553 06.03.18 10:44 Сейчас в теме
(15) это индекс не метаданных. Возможно временная таблица или вообще вы не туда смотрите!
Для отправки сообщения требуется регистрация/авторизация