Разработки для 1С. 1С оптимизация запросов


Оптимизация запросов - Разработки для 1С

Физический смысл:

     Обработка выполняет на различных параметрах 2 запроса (исходный и доработанный) – с тем, чтобы оценить их результаты по количеству и составу возвращаемых строк.

 

А. Вкладка “Основное”:

 

1. Вкладка “Основное” – содержит сведения, необходимые для управления функционалом и отображения результатов работы

2. Область исходного запроса. Содержит непосредственно текст запроса и кнопки “Проверить” (для проверки синтаксиса запроса) и “Конструктор запроса” (вызывает функциональность резактирования текста запроса в стандартном конструкторе запроса 1С)

3. Область доработанного запроса. Аналогично п.2

4. Область настроки параметров выполнения экспериментов.

     4.1.  – запускает механику сравнения. Причем, если обработка загружена в информационную базу, посредством типовой подсистемы “Дополнительные отчеты и обработки”, то выполнение происходт в фоне

     4.2.  Групповое управление пометками в таблице. Кнопка “Установить” – устанавливает пометки во всех строках, “Снять” – снимает пометки

     4.3.  Автоматическое заполнение таблицы параметров из запроса.

          4.3.1. Кнопка “Текст запроса” открывает форму редактирования текста запроса, заполняющего таблицу параметров (Подробнее в разделе Б.)

          4.3.2. Кнопка “Заполнить” – выполняет запрос из раздела Б. и заполняет в таблице параметров колонку “Параметры”.

     4.4. Кнопка “Очистить” – удаляет все строки из таблицы параметров

     4.5 Таблица параметров

          4.5.1. Колонка с флажками, если в строке установлен флажек – это значит, что данная строка параметров будет учавствовать в механизме сравнения запросов

          4.5.2. Колонка “Параметры” – содержит набор параметров, используемых в обоих запросах. Можно редактировать вручную 

          4.5.3. Колонка “Запрос №1 (исходный)” – содержит сведения, полученные в результате выполнения механизма (факт успешного выполнения запроса с указанными параметрами , количество строк результата запроса и время его выполнения)

          4.5.4. Колонка “Запрос №2 (доработанный)” – Аналогично п. 4.5.3

          4.5.5. Колонка “Прирост” – прировст производительности в процентах. Если доработанный запрос выполняется медленнее исходного – отобразится отрицательное число

          4.5.6. В подвале таблицы отображаются средние арифметические заначения времени выполнения запросов и прироста производительности.

 

Б. Форма редактирования текста запроса

1. Кнопка “ОК” – сохранение текста запроса

2. Кнопка “Отмена” – закрывает форму без сохранения текста запроса

3. Кнопка “Проверить”  – для проверки синтаксиса запроса

4. Кнопка “Конструктор запроса” – вызывает функциональность резактирования текста запроса в стандартном конструкторе запроса 1С

5. Поле текста запроса

 

В. Вкладка “Настройки”

1. Кнопка “Сохранить” – позволяет сохранить все настройки обработки, включаю тексты обоих запросов и таблицы параметров. Настроки сохраняются в файл с расширением “*.cqsettings”.

2. Кнопка “Загрузить” – загружает настройки из внешнего файла “*.cqsettings”.

3. Флаг “Использовать выгрузку результатов в файлы” – включет механизм выгрузки результатов запросов в хml-файлы. Полезно использовать, когда оба сравниваетмых запроса возвращают одинаковое количество записей, но существует вероятность что строки результатов запросов могут различаться. То есть, выгрузив результаты запросов во внешние [ml-файлы можно в далбнейшем сравнить их по сожержимому (например Total Commander, Araxis Merge и пр.).

     3.1. Примечание: Если флаг установлен, то в таблице параметров появляется дополнительная колонка (пометить для выгрузки в файл), а в командной панели кнопки  (для группового управления пометками выгрузки). То есть,      у пользователя появляется возможность выгружать в xml-файлы результаты запросов выборочно.

4. Поле “Каталог результов” – путь к папке, в которой будут созданный xml-файлы выгрузки результатов запросов

5. Поле “Имя файла для запроса №1” – имя xml-файла выгрузки для результатов исходного запроса

6. Поле “Имя файла для запроса №2” – имя xml-файла выгрузки для результатов доработанного запроса

     6.1. Примечание: Нажатие на “педальку”  открывает ткрыть список выбора существующих xml-файлов

 

Г. Примерный использования обработки

1. Имеем запрос с параметрами, который необходимо опртимизировать

2. Помещает исходный запросв в поле исходного запроса

3. Дорабатываем исходный запрос и помещает новый текст запроса в поле доработанного запроса

4. Отключаем флаг “Использовать выгрузку результатов в файлы” (на вкладке настроки)

5. Заполняет таблицу параметров необходимым количеством наборов параметров (либо ручками, либо используем заполнение с помощью запроса)

6. Устанавливаем флаги напротив необходимых строк таблицы параметров. Запустить сверку запросов!!!

7. Изучаем таблицу параметров (она теперь заполнена целиком). Путем редактирования текста 2го запроса, необходимо добиться, чтобы все запросы на всех наборах параметров успешно выполнились и количество строк в их результатах совпадало. Ну и процент прироста производительности имеет положительное значение

8. Установить флаг “Использовать выгрузку результатов в файлы” (на вкладке настроки). Указать расположение и имена xml-файлов выгрузки

9. Устанавливаем флаги выгрузки в xml-файл напротив необходимых строк таблицы параметров. Запустить сверку запросов!!!

10. С помощью строннего ПО сравниваем выгруженные файла по содержимому. Если файли идентичны, то поздравляю, запрос успешно оптимизирован

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

Обработка тестировалась на платформе 8.3.5. Работает на конфигурациях, основанных на БСП, либо потребуется незначительная доработка

1c-e.ru

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

Новый продукт в линейке программ интерактивного обучения, позволяющий программистам повысить уровень разработки и получить практические навыки оптимизации запросов 1С.

Если Вы сталкиваетесь с задачами сокращения времени исполнения запросов, но:

– Вы не знаете, как достигается повышение производительности

либо

– Знания Вами уже получены, но на практике оказалось все иначе

например, Shared Memory для современных СУБД включен по умолчанию,а обращение к полям составного типа давно уже не приводит к обращению к куче лишних таблиц

либо

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

тогда

Консоль оптимизации запросов – программа интерактивного изучения методов оптимизации – для Вас!

Задания представлены по следующим разделам:

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

– Использование специальных возможностей языка запросовРаздел рассматривает различные стандартные средства и методики, позволящие выбрать данные запросом оптимально

– Обеспечение использования индексов в запросахЗадания этого раздела посвящены оптимизации запросов 1С через “попадание в индекс”. Здесь Вы сможете получить информацию о том, как определить наличие индексов (созданных системой явно или неявно), как обеспечить их использование средствами СУБД.

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

– Самостоятельная работаНесколько непростых заданий для закрепления полученных знаний и выработанных навыков оптимизации.

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

 

Задание будет решено, если система автоматической проверки примет Ваше решение. Для этого необходимо добиться меньшей стоимости исполнения запроса.

 

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

 

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

Изучение методов оптимизации требует наличие базовых знаний по запросам 1С. Программа интерактивного изучения языка запросов и возможностей конструктора запросов представлена здесь: //catalog.1c-e.ru/public/255926/

Технология оптимизации запросов позволит не только ускорить работу механизмов проведения документов, но и выборки данных в отчетах. Для получения практических навыков разработки отчетов на СКД используйте программу: //catalog.1c-e.ru/public/315653/

 

Начать обучение в программе оптимизации запросов можно бесплатно (доступна половина заданий). Для этого необходимо:

  1. Скачать и установить бесплатную учебную платформу 1С Предприятие 8.3
  2. Скачать и установить Консоль изучения 1С Предприятие 8.3 (см. ниже)
  3. Скачать и установить шаблон учебной конфигурации (см. ниже)
  4. Создать новую базу по шаблону (п.3)
  5. Запустить ярлык Обучение v8edu и выбрать в списке созданную ИБ.

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

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

Бухгалтерия предприятия 3.0: //catalog.1c-e.ru/public/252228/

1С Документооборот 2.0: //catalog.1c-e.ru/public/458195/

Зарплата и управление персоналом 3.0: //catalog.1c-e.ru/public/307106/

Управление торговлей 11: //catalog.1c-e.ru/public/301622/

1С ERP 2.0: //catalog.1c-e.ru/public/320307/

Управление производственным предприятием 1.3: //catalog.1c-e.ru/public/290089/ 

Бухгалтерия гос учреждений 2.0: //catalog.1c-e.ru/public/315736/

 Для организации Интерактивного обучения и тестирования сотрудников вашего предприятия можно использовать и Корпоративный сервер: //catalog.1c-e.ru/public/424837/ 

1c-e.ru

Оптимизация запросов 1С:Предприятие – от теории к практике

Основные причины неоптимальной работы запросов

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

Эти факторы могут прямо или косвенно повлиять на то, что запросы будут работать неоптимально. Но я буду, в основном, говорить именно про текст запроса, потому что это – самая основная и первая причина неоптимальной работы запросов.

Чем «портят» запросы программисты?

Как это выглядит? Я вам из Барнаула привез самолетик, к которому спроектировал довольно большое крыло в надежде на то, что он так лучше полетит. Но происходит примерно так: самолетик падает плашмя вниз. То же самое с запросами. Разработчик, предполагая использование в запросе каких-то навороченных решений, может воспроизвести такой текст запроса, который «не полетит», поскольку его результат становится тяжелым, как и в случае с этим самолетиком.

Итак, сконцентрируемся на тексте запросов. Что может «утяжелить» запрос? Здесь перечислены основные причины такого «утяжеления», про все это подробно написано на всем известном сервисе http://its.1c.ru/, очень доступном, открытом – вы можете принимать это во внимание.

Безусловно, самым часто встречающимся случаем является неиспользование отборов внутри виртуальных таблиц. Я думаю, что нет ни одного разработчика 1С, кто не знает этого правила, однако в реальных решениях такие ошибки все-таки встречаются довольно часто. Причем их могут совершать даже разработчики с многолетним стажем

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

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

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

Почему-то иногда прикладные разработчики говорят: «подготовка подходящего покрывающего индекса – это не наша обязанность, мы же просто прикладные разработчики». Соответственно, когда нужно получить данные с отбором по полю A и C, они, не имея подходящего индекса, довольствуются тем, что происходит сканирование кластерного индекса или же таблицы.

Методика оптимизации запросов

Сама методика оптимизации запросов описана в открытых источниках (диск ИТС). Ничего нового (или почти ничего нового) я вам не скажу. Но важно научиться применять эту методику, вовремя вспомнить о ней, увидеть неоптимальный код в своем решении – это дано не каждому. Несмотря на это, сделать правильные выводы из готовых рекомендаций намного проще, чем увидеть проблему в своем коде самому.

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

Итак, методика оптимизации запросов у нас имеется, вы можете ее использовать, все замечательно. Однако ее практическое применение может оказаться с неожиданными результатами. Я о таких неожиданных результатах знал давно, поэтому специально для доклада подготовил несколько примеров.

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

Справа показаны замеры скорости исполнения, сделанные с помощью всем известной обработки с диска ИТС «Консоль запросов для управляемого приложения 8.3», позволяющей видеть затраты на исполнение запроса для сервера MSSQL. Как вы видите, в данном случае использование временной таблицы не привело к более быстрому результату, поскольку затраты на ее создание оказались более существенными, чем работа с вложенным запросом. Такое очень часто встречается на практике.

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

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

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

Например, на слайде показан текст запроса, демонстрирующий обращение к полю составного типа «Регистратор» (а именно к его вложенному свойству «Контроль цен»). Здесь видно, что запрос, в конечном счете, не производит обращения к документу «Реализация товаров и услуг», поскольку свойства «Контроль цен» у этого вида документов нет, и, соответственно,сама платформа не генерирует никаких дополнительных левых соединений. А на практике я встречаю чрезмерные усилия разработчиков (не всех, конечно), направленные на то, чтобы исключить лишние источники данных, хотя они в этом случае и так не будут подключены. И это тоже нередко встречающаяся ситуация.

Фильтрация внутри виртуальных таблиц

Еще одна интересная ситуация – это фильтрация внутри виртуальных таблиц.

Как вы понимаете, использование параметра «Отбор по периоду» при получении актуальных данных не требуется. И если произвести получение остатков на актуальную отметку времени без использования этого параметра, мы получим данные с использованием одного источника – физической таблицы итогов. А при указании в этом значении любого подходящего периода (например, будущего времени сегодняшнего дня, который тоже будет указывать на необходимость получения актуальных остатков), у нас уже произойдет получение данных из двух источников – таблицы итогов и таблицы движений. И в результате мы получим значительное снижение производительности запроса. Такая ситуация тоже очень часто встречается.

Использование критериев отбора для получения некластеризованного индекса

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

И опять же, эта теория описана на ИТС.

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

Неправильное использование критерия отбора

Однако при использовании критерия отбора для выборки определенных номенклатурных позиций из документов различных видов мы не получим той эффективности, которую можем получить, используя аналогичное по функциональности, но более объемное по написанию объединение запросов. Это связано с тем, что в первом случае физически на стороне СУБД будет сформирован гораздо более сложный запрос, чем во втором случае. Как вы здесь видите, запрос с объединением работает более эффективно, чем использование критерия отбора.

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

Это – те основные моменты, которые мы можем отметить в процессе оптимизации тех или иных запросов. И эта методика, как я уже говорил, описана в открытом источнике на ИТС. В частности, там есть информация о том, как можно, используя критерии отбора, получить нужный индекс, не меняя типовую конфигурацию.

Как правильно оптимизировать запросы?

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

Для этого у нас есть специальная обработка «Консоль запросов для управляемого приложения 8.3», позволяющая при использовании сервера MS SQL визуально увидеть план запроса, затраты, понесенные на его исполнение, и пр.

Продукт для интерактивного изучения методов оптимизации запросов

Как вы видите, вся статья связана с демонстрацией практических результатов, которые я получил в процессе переписывания неоптимальных запросов. Но как научиться оптимизировать запросы, если нет подходящих инструментов? Размышляя над этим, мы решили создать продукт«Интерактивное изучение методов оптимизации запросов».

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

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

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

Если у вас возникают какие-либо сложности, вы всегда можете обратиться к информационной поддержке:

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

Решение опубликовано на сайте Инфостарт – //catalog.1c-e.ru/public/374023/ .

Архитектура корпоративной системы интерактивного обучения

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

Порядок работы с сервером интерактивного обучения следующий:

Вот пример той статистики, которую видит руководитель подразделения. Статистика генерируется http-сервисом «Сервер интерактивного обучения».

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

****************

Данная статья написана по итогам доклада, прочитанного на конференции INFOSTART EVENT 2015 CONNECTION 15-17 октября 2015 года.

Приглашаем вас на новую конференцию INFOSTART EVENT 2017 COMMUNITY.

1c-e.ru


Prostoy-Site | Все права защищены © 2018 | Карта сайта