Оптимизация запросов в 1С
-

Оптимизация запросов в 1С

0
1981
30.08.2021 Айдар Фархутдинов

Содержание:

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

2.       Запросы с составным типом данных

3.       Оптимизация запросов в условиях соединения

4.       Запрос по виртуальным таблицам

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

6.       Логическое «ИЛИ» в условиях отбора в запросе


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


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


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


Рассмотрим пример выполнения неправильного запроса, предназначенного для отбора:



Рис. 1 Плохо оптимизированный запрос для отбора


И выполнение аналогичного примера запроса, предназначенного для отбора, но корректно оптимизированного:



Рис. 2 Оптимизированный запрос, предназначенный для отбора  


2.    Запросы с составным типом данных


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


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


Рассмотрим негативный пример запроса:



Рис. 4 Неоптимизированный запрос с составным типом данных


В данном примере происходит обращение не к одной конкретной таблице, а к целым двадцати двум таблицам внутри базы с данными, так как данный регистр имеет 21 тип регистраторов.


Чтобы оптимизировать запрос, лучше пожертвовать объемом данных, которые хранятся, в пользу более «гибкого» программного кода, который даёт большую производительность. Заменой вышеуказанного запроса станет следующая конструкция:



Рис. 5 Оптимизированный запрос с составным типом данных


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



Рис. 6 Вариант оптимизации запроса в 1С  


3.    Оптимизация запросов в условиях соединения


Рассмотрим, как оптимизировать следующий вид запросов – тех, которые определяют условия соединения. Сразу стоит оговориться, что на оптимизацию не будут положительно влиять какие-угодно подзапросы, так как они замедляют процессы. В подобных ситуациях лучше всего воспользоваться ВТ. Чтобы получить соединение, необходимо воспользоваться объектами метаданных, а также ВТ, а перед этим – провести индексацию по полям, в которых происходит соединение.


Ниже приведён негативный пример с подзапросами:



Рис. 7 Пример подзапросов для определения условий соединения


А вот пример того, как переделать то же, но с учётом оптимизации:



Рис. 8 Оптимизация запроса в условиях соединения  


4.    Запрос по виртуальным таблицам


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


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


Одной из наиболее распространённых ошибок является использование условия для тех полей, которые не имеют индексации. Данное действие негативно влияет на оптимизацию запроса, так как СУБД не будет работать оптимально в случае наличия запроса по тем полям, которые не подлежат индексации. Стоит отметить, что даже для временных таблиц нужно проводить индексацию по полям. И каждое условие должно сопоставляться соответствующему индексу. Чтобы определить соответствующий индекс, нужно проверить его на наличие таких требований:


·        в индексе содержаться все поля из условия;

·        все номера полей перечисляются в начале индекса;

·        все вышеуказанные отборы записаны по порядку.


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


6.    Логическое «ИЛИ» в условиях отбора в запросе


Лучше всего избегать использования логической связки «ИЛИ» внутри условий отбора в запросе, так как при выполнении данного оператора загружаются оба объекта/файла, что также негативно сказывается на оптимизации запросов.


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

Айдар Фархутдинов

Задать вопрос автору статьи
Тема вопроса*
Ваше имя*
E-mail или телефон*
Ваш вопрос*
 

Добавить комментарий
Текст сообщения*
Защита от автоматических сообщений
 
Теги
# абота Риелторского Агентства # Управление торговлей 11 #Забалансовый счет #Контекстное меню #Параметры запуска #Работа Риелторского Агентства # 1C # CRM-система # Cинтаксис-помощник # Cинхронные методы работы # Cправочник номенклатуры # PDF документами # PowerShell # XML-файл # Бизнес-процесс # Виды событий оповещения # Возврат товаров # Глубина анализа # Графические объекты # Динамический список # Документ заказ клиентов # Документ заполнен # Документ Отбор (размещение) товаров # Документ Отгрузка товаров ИС МП # Документ Приобретение товаров и услуг # Документ УПД # Документы продажи # Доступ на ТСД # ДтКт # ЕАЭС # Задержка зарплаты работодателем # Заказ на перемещение # Закладка Администрирование # Зарплата и кадры # Имя таблицы # ИТС # Кабель NYM(Севкабель) 3x5.5 # Книга учета доходов и расходов # Курс валюты # Лицо с правом подписи # Лицо, имеющее право подписи документов # Маркировка цифровыми кодами # Минимальные цены продажи в 1С # Настройка НСИ и разделов # Настройка ценообразования # НДФЛ # Нематериальные активы # Нормативно-правовые документы # Обмен электронными документами # Оплата через банк # Оптовые продажи # Основное ответственное лицо организации # Остаток товара на складе # Отчет комиссионера # Передача на комиссию # Перемещение ТС и оборудования # Проведение инструктажа # Продажи или Закупки # Прочие доходы # Пункт Подключить обработки # Пункт Сервис # ПФР и ФФОМС # Работа ТС # Расчёт зарплаты # Расчет налога УСН # Расчетные счета # Режим использования модальности # Система «Честный знак» # Система GS1 # Списание на расходы # Справка-расчет налога УСН # Страховые взносы # Табель учёта рабочего времени # Таблица формы # Таблица формы «Сотрудники» # Товары # Установка цен на товары # Формат Цифровой Маркировки # Форматированное письмо # Функция Дата # Функция ДеньГода # Функция ДеньНедели # Центральный Банк России # Цены номенклатуры 2.5 # Эквайринговый терминал # Элементы #1.6-НДФЛ #1С Бухгалтерия #1С Договоры #1С: CRM #1С: ERP #1С: ERP Управление строительной организацией #1С: ERP. Управление буровой компанией #1С: WMS Управление складом #1С: Аренда и управление недвижимостью #1С: БУХ #1С: Договорчики #1С: Документооборот #1С: ЗУП #1С: Интеграция #1С: КА #1С: Колледж #1С: Конвертация данных #1С: Модули #1С: Платформа #1С: Предприятие #1С: Розница #1С: Сценарное тестирование #1С: ТОИР #1С: УАТ #1С: УКФ #1С: Университет #1С: УНФ #1С: УПП #1С: Управление строительной организацией #1С: УТ #1С: УХ #1С:ERP #1С:БГУ #1С:БП #1С:Риелтор #1С:Управление холдингом #1С.6-НДФЛ #ADO #APACHE #API #canonical #com-объекты #Cинтаксис-помощник #Cопроводительных документов #Cправочник БИК #Excel #Excel в 1С #FTP-сервер #GoogleDrive #Googleаккаунт #GUID #HTTP #ITIL #Koderline: Управление медиа-холдингом #Koderline: Управление проектами строительства скважин #LINUX #MS SQL Server #PDF #ragent.exe #SOAP-протокол #USB- ключ #WEB #WEB-сервисы 1С #Word #WS-ссылки #XDTO-объект #XML #XML-обмен #Авансовый платеж #Администрирование 1С #Адрес URL описания #Адресный классификатор #акты в 1С #Аутентификации операционной системы #База XML #База данных #Балансовый метод #Балансовый расчет #Банковские счета #Безопасность сервера #Бесшовная интеграция #Бизнес-процесс #БИТ.Финанc #Битрикс24 #Блокировка данных #Блокировки в 1С #БСП #БУ #Бурение скважин #Бухгалтерская отчётность в МСФО #Бухгалтерский отчет #Бюджетирование #Валовая прибыль #Ввод команд #Ввод пароля #Ввоз товаров #Веб-сервер #Веб-сервер Apache #Вид договора #Вид Характеристики #Вкладка Документы #Внедрение #Внедрение ERP #Внешний вид формы #Внешнюю обработку #Возврат от покупателя #Временные разницы #Временные таблицы #Всплывающие ошибки #Выбор каталога #Выбранные файлы #Вызов процедуры #Выпадающий список #Выплата аванса #Выплата отпускных сотруднику #Выполнение запроса #Выполнение кода #Выполнение транзакций #График отпусков #ГТД #Дата действия договора #Дата документа #Движение документа #Декларация по НДС #Диагностика ошибки #Директория сервера #Дистрибутивы программ #Документ Заказ клиента #Документ Отпуск #Документ1 #Дополнительный оплачиваемый отпуск #Доработка конфигурации #Доступ к файлам #Журнал проводок #Журнал регистрации #Журнал транзакций #Журналы #Загрузить Значения #Загрузка цен в 1С #Задача для 1С #Заказ-наряд #Закладка Торговля #Закрытие месяца #Закрытие сделки #Заменить #Запись регистра сведений #Заполнения полей #Запросы 1С #Заработная плата #Зарплата и управление персоналом #Импорт товара #Имущество предприятия #инвентаризационная опись #Инвентаризация склада #Интеграция 1С #Интервал dpi #Интерпретатор языка #Интерфейс пользователя #Информационная база #История пользователя #Источник данных #Кадровые документы #Кадровый документ #КАК ОТРАЖАЮТСЯ ТОВАРЫ В ПУТИ 1С #Как сделать в 1С #Карточка должности #Карточка номенклатуры #Карточка Объекта недвижимости #Касса ККМ #Кассовый документ #Квалификационные надбавки #Классификаторы и курсы валют #Классификаторы и курсы валют #Клиент-серверная схема #Клиент-серверный режим #Код доступа #Код ЦМТ #Код языка #Команда вызова #Командная строка #Конвертация данных #Контроль документов #Конфигурация 1С #Конфигурация 1С ЗУП 3.1 #Конфигурация системы 1С #Копирование настроек пользователей #Корпоративное сопровождение #Корректировка расчётов с учредителем #Криптография данных #Критерии отбора документов #Курс валюты #Курсовые разницы #Левое соединение #Лизинг #Лицензии 1С #Лицензионный договор #Лицензия 1С КОРП #Лицензия 1С ПРОФ #Личные документы #Локальный каталог #Маркетинговая акция #Массив Номенклатур #Массовая регистрация отгулов #Меню Отчет #Место хранения #Метод объекта #Метод устранения ошибки #Методы устранения ошибки #Механизм Анализа Данных в 1С #Механизм записи #Мобильное приложение #Мобильный клиент #Моделирование #Модель данных #Модуль Диадок #Монопольный режим #МРОТ #МСФО #Налоги #Налоговая декларация #Налоговый актив #Налоговый регистр #Налоговый учет #Написание запроса #Настройка панели #Настройка параметров #Настройка пользователя #Настройка системы #Настройки пользователя по умолчанию #Начальная таблица #Начисления Арендной платы #Новый Массив #Нормативно-справочная информация #Облачный сервис #Обмен между базами #Обмен сведениями #Обновления #Обособленное подразделение #Обработка проведения документов #Общие ознакомительные рассылки #Объект системы #Объективность информации #Объектная база данных #Окно сообщений #Оперативная аналитика #Операции в 1С #Оплата агента #Оплата по квитанции #Оповещение по видам события #Оптимизация #Организация #Организация хранения #ОС и НМА #Основное окно #Остатки взаиморасчетов #Остатки товаров на складах #Остаток товара #Отпуск #Отчет комитенту #Отчетность #Отчетный период #Отчеты в 1С #Оформление документа #Оформление перевода работника #Оценка задач #Параллельный учет #Параметр «Количество» #Параметры отбора #Параметры подключения #Партнер #Передача данных #Передача неисключительных прав #Перемещение отчета #Перенос данных #Перенос цен из Excel в 1С #Перечисление денежных средств #Период отбора #Периодичность ДЕНЬ #Периодичность МЕСЯЦ #Печатная форма #Печатная форма документа #План счетов #Планирование #Планировать события #Платежный документ #Погашение обязательств #Подчиненный справочник #Поле Ввода Значение Субконто #Полезные обработки #Политика учета #Пользователь Администратор #Пользовательский режим #Поступление денежных средств #Поступление основных средств #Потенциальный контрагент #Права доступа #Правила обмена #Правое соединение #предопределенные элементы справочников #Прием на работу #Принцип работы 1С #Приходная накладная #Приходно-кассовый ордер #Проведение документов #Проведение инвентаризации #Проводки 1С #Проводок документации #Программа 1С #Программирование в 1С #Программные права #Программный код #Продажа маркированной продукции #Продажа ТМЦ #Продажа товара #Продажи #Продление #Производственный план #Производство #Просмотр #Процедура и функция #Пункт «Касса» #Путь к файлу #Работа с объектами в 1С #Рабочий сервер #Раздел Справочники #Расположение ссылки #Расторжение #Расходная накладная #Расходный ордер #Расходы по амортизации #Расчет зарплаты #Расчет НДФЛ #Расчетные документы #Расширение конфигурации #Расширение прав доступа #Расширение функционала #Регистр бухгалтерского учета #Регистр бухучета #Регистр данных #Регистры бухгалтерии #Регистры движения документов #Регламентированная отчетность #Регламентное задание #Режим записи #Режим использования модальности #Режим конфигуратор #Режим РИБ #Резерв отпусков #Результаты поиска #Реквизит «СпЗнч» #РМК #РМК кассира #РСБУ #С # #Сверка данных учёта НДС #Свойства характеристики номенклатуры #Свойство ячейки таблицы #Сдельный заработок #Сеанс Администратор #Сегмент номенклатуры #Сервис-деск #Сетевой ключ защиты #Сетевой ключ защиты #Сетевые структуры системы #СЗВ-СТАЖ #Синхронизация данных #Система программы #СКД #Служба ИТ #Служба НСИ #Соединение COM в 1С платформе #Соединение СОМ в 1С платформе #Список документов #Список номенклатуры #Список прав #Справочник Лиды #Сравнение конфигураций #Строка «Касса (ККМ)» #Схема отчетности #Счет-фактура #Табличная часть #Табличная часть обработки #Таможенные пошлины #Текстовый формат #Текущая Строка #Территориальная привязка #Территориальные рамки #Тестирование 1С #Техническое задание #Тип данных #Тип свойства #Тип строки #Типы данных ссылки #Толстый клиент #Тонкий клиент #Торговое оборудование #Транспортная логистика #Универсальные коллекции #Управление проектами #Управленческое взаимодействие #Условие предоставления скидки #Условия труда #Установка цен номенклатуры #Учет зарплаты #Учетная политика организации #Файл обмена данными #Файловая база #Файлы обмена #Физический ключ #Финансовый результат #Финансовый учет #Форма ввода #Форма выбора элемента #Формат MicrosoftExcel #Формат даты #Формирование отчета #Формирование отчета #Функционал МРМ #Х-точка #Характеристики Товаров #Хранение информации #Хранилище настроек #Хранить историю изменений #Ценообразование #Центральный узел #Чтение #Шаблон обновления #Шапка отчета #Эквайринговая операция #Экзамен 1С #Экспорт товаров #Экспортная процедура #Электронная подпись #электронные подписи #элемент справочника #Элемент языка #Язык программирования #Яндекс-диск или Google-диск #Яндекс.Касса 1С под Linux 1С:УНФ Email или телефон Работа с объектами в 1С тип да Функциональные опции в 1С
Услуги программиста 1С
Получите специалиста  
для решения всех задач
в области 1С
Программы 1С
Цены и подробное описание программ 1С:Предприятие 8.