Скд необязательный параметр в запросе

1С СКД. Параметры и необязательные параметры.

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

Параметры в запросе 1С СКД.

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

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

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

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

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Таким образом этот блок настраивается в конструкторе.

Если значение параметра не задано, то построение СКД будет невозможно и будет выдана ошибка, поэтому такие параметры называют “обязательными” или “жесткими”.

Расширение языка запросов для СКД.

Выбрать.

Этот блок располагается в запросе типа выборка данных пакета запросов СКД в первом запросе объединения между перечнем полей и “ИЗ” и заключается в фигурные скобки.

В этом блоке мы перечисляем поля, которые пользователь может выбирать для вывода, группировки и упорядочивания. Конструкция «.*» в параметре “Марка.*” позволяет выбирать для вывода, группировки и упорядочивания дочерние поля значения, например, Марка.Код. Слово “КАК” позволяет задать псевдоним, например, “Ссылка КАК Машина”. Поля в этом блоке попадают в перечень полей набора, даже если отключено автозаполнение. Если автозаполнение включено, то упомянутые поля попадают в соответствии с тем, как они настроены расширением кода, то есть если ссылочное поле без конструкции “.*” дочерние поля доступны не будут, если указан псевдоним — именно он попадет в перечень полей набора.

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Таким образом этот блок настраивается в конструкторе.

При автоматическом заполнении полей набора данных, для не включенных в блок расширения “ВЫБРАТЬ”, добавляются все поля списка выборки и их дочерние поля. Они становятся доступными для выбора, упорядочивания, группировки, отбора. Также добавляются поля, которые упомянуты в параметре “Условия” виртуальных таблиц как доступные для отбора.

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

Блок расширения “ГДЕ” может быть расположен после или вместо обычного блока “ГДЕ” в любом запросе, подзапросе, запросах объединения и заключается в фигурные скобки. Для присвоения отбору псевдонима используется конструкция “КАК”. Псевдоним нужно использовать чтобы отбор производился конструкцией расширения языка запросов, но не происходил автоматически по наименованию поля.

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

Если автозаполнение включено, и это поле включено в блок расширения “ВЫБРАТЬ” тогда настройки обоих блоков объединяются. Если не включено в “ВЫБРАТЬ” то поля попадают доступными для вывода, группировки, отбора и упорядочивания.

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

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

Параметры в блоке «ГДЕ» не обязательны для заполнения, поэтому эти параметры называют “необязательными” или “мягкими”.

Также в блоке “ГДЕ” вместо параметра может быть произвольное выражение с использованием конструкции ВЫБОР или параметров со страницы “Параметры” СКД. Правда в последнем случае вид сравнения необходимо указывать конкретно.

Нужно с осторожностью использовать вид сравнения МЕЖДУ поскольку:

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

Если параметры НачалоПериода и КонецПериода будут заданы, то система получит документы за указанный период.

Если какой-то один из параметров не будет задан, то система выдаст ошибку.

Один из вариантов решения это разбить МЕЖДУ на два условия чтобы система не выдавала ошибку в случае одного незаполненного параметра.

Это же замечание относится к любым выражением с использованием нескольких параметров.

Параметры виртуальных таблиц.

В параметрах виртуальных таблиц в отличие от предыдущих блоков, каждый параметр заключается в фигурные скобки. В полях относящихся к периоду название параметра ставится с &. Пример &ДатаНачала. В поле “Условие” параметры оформляются аналогично блоку “ГДЕ”.

Поведение параметров из поля “Условие” при снятии или установке галочки “Автозаполнение” также аналогично блоку «ГДЕ».

Параметры из полей периода попадают на страницу “Параметры” СКД. Если автозаполнение включено и в поле периода параметр не вписан, параметры с именем поля периода будут автоматически созданы на странице “Параметры” СКД.

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

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

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

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

Если автозаполнение включено и в поля периода не вписаны “мягкие” параметры компоновки данных то параметры с именем поля периода будут автоматически созданы на странице “Параметры” СКД и текст запроса:

будет соответствовать следующему:

В этом случае “мягкие” параметры также будут иметь приоритет над “жесткими”.

Особенности настройки страницы “Параметры” СКД.

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Обзорный вид страницы.

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

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

Строка параметра имеет следующие реквизиты:

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

Заголовок — название, выводимое пользователю.

Тип — определяет тип параметра. Иногда при выборе дат периода, пользователю не нужно указывать время. Тогда нажав на “…” можно указать состав даты — Дата.

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

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

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

Доступен список значений — определяет доступность параметру принимать значение “список значения”.

Значение — предустановленное значение параметра. Типа параметра. Для ссылочного типа доступны для выбора только предопределенные данные.

Выражение — выражение, значение которого примет параметр. Что примечательно здесь могут использоваться как функции встроенного языка запросов, так и функции встроенного языка программирования и даже функции из общих модулей. К примеру, параметру ТекДата присваивается значение функции встроенного языка программирования ТекущаяДата().

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

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

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Иногда, для повышения удобства пользователю для выбора периода лучше дать не два поля с типом Дата, а одно поле с типом Стандартный Период. Тогда, к примеру, создаем три параметра: “Период” с типом СтандартныйПериод, “ПериодНачало” и “ПериодОкончание” с типом Дата. Первый параметр без ограничения доступности. Вторые с ним. В выражение “ПериодНачало” пишем “&Период.ДатаНачала”, в “ПериодОкончания” — “&Период.ДатаОкончания”.

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Даты начала и конца стандартного периода также содержат и время. ДатаНачала имеет время 00:00:00, а ДатаОкончания 23:59:59. Получится что пользователь выберет стандартный период в “Период” а разработчик будет использовать корректные “ПериодНачало” и “ПериодОкончание”.

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Параметр функциональной опции — используется в механизме функциональных опций.

Включать в доступные поля — включает параметр в доступные поля для выбора в настройках.

Ограничение доступности — ограничивает возможность изменения значения параметра пользователем.

Запрещать незаполненные значения — если установлено и значение параметра не заполнено — отчет не сформируется и выдаст ошибку.

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

Параметры редактирования — содержит настройки редактирования как у поля формы.

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Страница “Параметры” блока “Настройки” страницы “Настройки”.

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

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

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

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

В пользовательских настройках мы можем включить параметр в пользовательские настройки. Установим режим редактирования обычный. Тогда он будет доступен в форме, вызываемой кнопкой “Настройки…”.

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Если Режим редактирования установить Быстрый доступ, то параметр появится на форме.

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Если у параметра “Период” представление заполнить строкой “ПеРиОд”, то вместо название будет показано содержания поля представление.

Параметры СКД на форме.

Если у отчета СКД нет формы, то платформа создаст автоматическую, на которой будут табличный документ результата, кнопки управления и быстрые пользовательские настройки.

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

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

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Для этого в созданной форме в конфигураторе вытаскиваем на форму Пользовательские настройки из Компоновщика отчета.

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

В некоторых случаях параметр не прост, и для его расчета нужен некий алгоритм с циклом или ветвлениями. К примеру если отчет формируем в понедельник то в отчете сравниваются продажи по дням позапрошлой и прошлой недели, а в остальные дни недели сравниваются продажи по дням прошлой и текущей недели. Получается у нас от значения дня недели текущего дня зависит сразу четыре параметра: &НачалоПрошлойНедели, &КонецПрошлойНедели, &НачалоТекущейНедели и &КонецТекущейНедели. А еще нам надо дать возможность пользователю формировать отчет как будто он сформирован вчера или неделю назад. В таком случае мы создаем реквизит формы ТекДата типа Дата. Выводим его на форму. В событии ПриИзменении() пишем.

Таким образом можно программно менять параметры из формы.

Резюме.

Параметры это ключевой инструмент для управления отчетом. Использование параметров дает возможность решить множество прикладных задач, таких как калькуляция на основе информации в базе и значений введенных интерактивно для конкретной калькуляции и многих других. В данной статье рассмотрены практически все относящиеся к параметрам механизмы и особенности. Рамках статьи не рассмотрен блок “Характеристики” Расширения языка запросов для СКД поскольку он не касается параметров. Не рассмотрена настройка параметра “Параметр функциональной опции” поскольку ее описание лучше включить в статью по функциональным опциям.

Источник

Работа с запросами в 1С СКД. Примеры использования расширения языка запросов СКД

Работа с запросами в 1С СКД. Примеры использования расширения языка запросов СКД

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

Если мы не задаем ни один параметр, выполняется запрос :

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Если мы задаем, например, дату начала, то выполняется другой запрос:

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

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

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

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

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

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

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

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

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Данный отчет мы создавали в рамках нашего курса по практическому применению СКД

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

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

При этом в параметры автоматически добавляется 2 параметра – «НаДату» с ограничением доступности и параметр «НаДатуКомпоновка» доступный пользователю. Смысл такой конструкции в следующем – если значение параметра «НаДатуКомпоновка» используется, то в запрос передается оно, если не используется, то в запрос передается значение параметра «НаДату», в котором можно, например, в выражении указать какое-то значение по умолчанию. Если в запросе не указать необязательный параметр «НаДатуКомпоновка», то СКД автоматически добавит (для регистра сведений) такой параметр с именем по умолчанию – «Период».

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

Управление местом применения отбора и доступностью

Иногда при разработке отчета на СКД возникает необходимость в тонкой настройке места применения отбора.

Рассмотрим на таком (пусть искусственном) примере. Допустим нам в отчете нужно вывести все расходные накладные и все приходные накладные, связанные с номенклатурой из расходных накладных. Напишем такой запрос:

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

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

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Без отбора отчет работает нормально:

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

С отбором работает неверно (пропал поставщик):

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Почему так случилось, разберем в следующем разделе «Особенности работы запросов в СКД».

Изменим запрос таким образом:

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Самое главное здесь отключить опцию «Автозаполнение». Только в этом случае система понимает, что отбор по контрагенту нам нужен только в последнем запросе пакета и отчет работает, так как нам нужно:

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Важно также заметить как заполнились ограничения доступности полей:

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

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

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Серия статей по СКД

Автор курсов образовательного проекта Profession Store. Павел Шемякин

Источник

Запросы 1С СКД. Возможности и ограничения

При использовании подсистемы СКД первое, с чем вы столкнетесь это необходимость написания запроса. Конечно, система компоновки данных умеет строить отчеты без использования запросов, например с помощью набора данных объект вы можете сделать отчет из таблицы значений. Но 90% отчетов, которые вы будете создавать с помощью СКД, потребуют написания запроса. Поэтому важно знать об особенностях работы с запросами в СКД, ограничениях, способах и инструментах поиска ошибок.

Если у вас хоть раз возникал вопрос: почему запрос в консоли запросов выдает правильные данные, а в вашем отчете на СКД нет, то в этой статье вы найдете ответ.

Возможности и ограничения языка запросов при использовании в СКД

В 1С СКД можно использовать практически все возможности языка запросов 1С:

В 1С СКД недоступны:

В 1С СКД дополнительно с помощью расширения языка запросов 1С для СКД имеется возможность:

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

Расширение языка запросов 1С для СКД

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

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

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Как известно, во многих типовых конфигурациях в 1С используется механизм дополнительных реквизитов, когда к объектам конфигурации пользователь может самостоятельно, без изменения конфигурации, добавить дополнительные реквизиты. Чтобы предоставить пользователю возможность работы с этими реквизитам в отчетах, построенных на СКД, используется механизм подключения характеристик. С помощью специального оператора «ХАРАКТЕРИСТИКИ» программист может привязать характеристики к выбранным объектам отчета. При этом необходимо указать тип объекта, к которому производится подключение характеристик, список дополнительных свойств для данного объекта, таблицу, в которой хранятся значения этих свойств.

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

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

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Используя небольшую хитрость, которую мы показывали в нашем курсе по СКД можно использовать эти реквизиты и в режиме конфигуратора:

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Как вы заметили, все элементы расширения языка запросов для СКД заключены в фигурные скобки «<>», чтобы отличать их от основных элементов запроса.

Кроме подключения характеристик расширение языка запросов используется для:

Все в одном месте хорошо описано в этой статье.

Автор курсов образовательного проекта Profession Store. Павел Шемякин

Источник

Работа с запросами в 1С СКД. Примеры использования расширения языка запросов СКД

Работа с запросами в 1С СКД. Примеры использования расширения языка запросов СКД

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

Если мы не задаем ни один параметр, выполняется запрос :

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Если мы задаем, например, дату начала, то выполняется другой запрос:

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

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

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

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

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

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

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

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

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Данный отчет мы создавали в рамках нашего курса по практическому применению СКД

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

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

При этом в параметры автоматически добавляется 2 параметра – «НаДату» с ограничением доступности и параметр «НаДатуКомпоновка» доступный пользователю. Смысл такой конструкции в следующем – если значение параметра «НаДатуКомпоновка» используется, то в запрос передается оно, если не используется, то в запрос передается значение параметра «НаДату», в котором можно, например, в выражении указать какое-то значение по умолчанию. Если в запросе не указать необязательный параметр «НаДатуКомпоновка», то СКД автоматически добавит (для регистра сведений) такой параметр с именем по умолчанию – «Период».

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

Управление местом применения отбора и доступностью

Иногда при разработке отчета на СКД возникает необходимость в тонкой настройке места применения отбора.

Рассмотрим на таком (пусть искусственном) примере. Допустим нам в отчете нужно вывести все расходные накладные и все приходные накладные, связанные с номенклатурой из расходных накладных. Напишем такой запрос:

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

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

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Без отбора отчет работает нормально:

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

С отбором работает неверно (пропал поставщик):

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Почему так случилось, разберем в следующем разделе «Особенности работы запросов в СКД».

Изменим запрос таким образом:

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Самое главное здесь отключить опцию «Автозаполнение». Только в этом случае система понимает, что отбор по контрагенту нам нужен только в последнем запросе пакета и отчет работает, так как нам нужно:

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Важно также заметить как заполнились ограничения доступности полей:

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

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

Скд необязательный параметр в запросе. Смотреть фото Скд необязательный параметр в запросе. Смотреть картинку Скд необязательный параметр в запросе. Картинка про Скд необязательный параметр в запросе. Фото Скд необязательный параметр в запросе

Серия статей по СКД

Автор курсов образовательного проекта Profession Store. Павел Шемякин

Источник

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *