Установка необязательного параметра запроса

10.02.23

Разработка - Запросы

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

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

 

 

Например, в нем есть условие.

ВЫБРАТЬ Док.Ссылка ИЗ Документы.Реализация КАК Док
ГДЕ Док.Организация = &Организация

 

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

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

Но это не наш метод. Мы будем использовать такую конструкцию:

ГДЕ (&ОтборПоОрганизации = ЛОЖЬ ИЛИ Док.Организация = &Организация)

 

Тогда в модуле формы в процедуре ПриОткрытии нам нужно установить параметр ОтборПоОрганизации

ОтборПоОрганизации = ЗначениеЗаполнено(Организация);
Запрос.УстановитьПараметр("ОтборПоОрганизации", ОтборПоОрганизации);

 

Такой же код будет и в процедуре ОрганизацияПриИзменении

При этом несмотря на то, что в условии запроса есть оператор ИЛИ, такое условие не приводит к замедлению запроса, индекс все равно используется.

Запросы параметры динамический список

См. также

Инструментарий разработчика Роли и права Запросы СКД Программист Руководитель проекта Платформа 1С v8.3 Управляемые формы Запросы Система компоновки данных Платные (руб)

Инструменты для разработчиков 1С 8.3: Infostart Toolkit. Автоматизация и ускорение разработки на управляемых формах. Легкость работы с 1С.

15500 руб.

02.09.2020    183650    1023    403    

966

Обновление 1С Запросы Программист Платформа 1С v8.3 1С:ERP Управление предприятием 2 Абонемент ($m)

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

2 стартмани

06.02.2025    2147    17    XilDen    26    

36

Запросы Программист Платформа 1С v8.3 Запросы 1C:Бухгалтерия Бесплатно (free)

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

03.12.2024    5621    artemusII    11    

23

Запросы Программист Бесплатно (free)

Увидел cheatsheet по SQL и захотелось нарисовать подобное, но про запросы.

18.10.2024    13030    sergey279    18    

65

Запросы Программист Платформа 1С v8.3 Запросы 1C:Бухгалтерия Бесплатно (free)

Столкнулся с интересной ситуацией, которую хотел бы разобрать, ввиду её неочевидности. Речь пойдёт про использование функции запроса АВТОНОМЕРЗАПИСИ() и проблемы, которые могут возникнуть.

11.10.2024    8125    XilDen    36    

90

СКД Механизмы типовых конфигураций Запросы Программист Платформа 1С v8.3 1С:Зарплата и кадры государственного учреждения 3 1С:Зарплата и Управление Персоналом 3.x Россия Бесплатно (free)

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

20.08.2024    3131    PROSTO-1C    0    

23

Запросы Программист Запросы Бесплатно (free)

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

16.08.2024    10711    user1840182    5    

29
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. sapervodichka 6957 10.02.23 09:23 Сейчас в теме
Выбор &Организация = Значение(Справочник.Организации.ПустаяСсылка) Тогда Истина Иначе Док.Организация = &Организация Конец
abasovit; корум; DrAku1a; GutaGroup; demon_infernal; TitBit_infostart; +6 Ответить
3. Serg2000mr 696 10.02.23 10:37 Сейчас в теме
(1) ВЫБОР - это функция. Ее использование в условиях запроса и условиях соединения приводит к невозможности использования индекса и радикальному замедлению работы запроса.
6. sapervodichka 6957 10.02.23 10:40 Сейчас в теме
(3) а о каком индексе идет речь если обход всех организаций ведется? (если только поле Организация стоит индексировать в документе, а если не стоит?...)
8. Serg2000mr 696 10.02.23 11:29 Сейчас в теме
(6)
о каком индексе идет речь


Как правило, это не единственное условие в запросе. Короткий запрос был приведен для упрощения восприятия.
9. user1146461 10.02.23 15:00 Сейчас в теме
(6) а если я передам в параметр НЕОПРЕДЕЛЕНО))
10. sapervodichka 6957 10.02.23 15:39 Сейчас в теме
(9) &Организация В (Значение(Справочник.Организации.ПустаяСсылка), НЕОПРЕДЕЛЕНО, NULL)
12. Serg2000mr 696 10.02.23 18:55 Сейчас в теме
(10) Тоже хана использованию индекса. Не учите плохому )
13. sapervodichka 6957 10.02.23 20:37 Сейчас в теме
(12) а ты научись учить и контекст выделать: показать как и учить плохому - это совершенно разные вещи (про твой индекс я уже два раза ответил, его для реквизитов документа нет, если не поставить вручную)
14. Serg2000mr 696 10.02.23 20:40 Сейчас в теме
(13) тыкать не нужно, равно как и командовать.
15. sapervodichka 6957 10.02.23 21:12 Сейчас в теме
(14) тыкать и говорить ты как равному - это разные вещи, пока тогда (показанный в статье отбор является 100% стандартным из любой конфигурации: Использовать отбор + сам отбор, лично мне не особо интересен)
2. SerVer1C 882 10.02.23 09:52 Сейчас в теме
ГДЕ &Организация = ЗНАЧЕНИЕ(Справочник.Организации.ПустаяСсылка) ИЛИ Док.Организация = &Организация
DrAku1a; akR00b; +2 Ответить
4. Serg2000mr 696 10.02.23 10:39 Сейчас в теме
(2) Тоже вариант неправильный, выведутся результаты только с незаполненной организацией, а нужны все результаты без отбора
5. SerVer1C 882 10.02.23 10:40 Сейчас в теме
11. Serg2000mr 696 10.02.23 18:52 Сейчас в теме
(5) Ошибся, вариант правильный, можно и так. Насчет использования индекса не могу сказать, план запроса не проверял для такого условия.
7. sapervodichka 6957 10.02.23 10:52 Сейчас в теме
(4) у SerVer1C рабочий вариант =)) в моём я его тык-тык написал поиск по индексу использоваться не будет, но у Организации и индекса то по умолчанию нет, это же реквизит (в системные индексы по умолчанию не входит если не отметить к индексированию). В остальном ты прав +100 Выбор не индексируется, а вот у SerVer1C как раз норм вариант
16. TMV 11 10.02.23 22:36 Сейчас в теме
Это ж отчет на СКД. Какие параметры при открытии формы?! Все гораздо проще:
ВЫБРАТЬ
	АвансовыйОтчет.Ссылка КАК Ссылка
ИЗ
	Документ.АвансовыйОтчет КАК АвансовыйОтчет
{ГДЕ
	АвансовыйОтчет.Организация.*}
ixijixi; EvgeniyOlxovskiy; аколит; DrAku1a; bilex; Рамзес; Zergej; Dimkasan; Invocater; +9 Ответить
17. Serg2000mr 696 18.02.23 19:55 Сейчас в теме
Про такой вариант я знаю, можно и так. Но я описал универсальный подход для любых запросов. В том числе и в отчетах на СКД, формах с динамическими списками и т.д.
18. exciter 18.03.23 18:24 Сейчас в теме
И (НЕ &ОтборПоОрганизации или Организация = &Организация)
19. user1126480 21 25.11.23 12:33 Сейчас в теме
А как в параметрах виртуальной таблицы не пробовали? У меня не получается, скобки убираются конструктором и ошибка.

РегистрНакопления.ЗаказыПокупателей.Остатки(
| ,
| &ОтборПоКонтрагент = ЛОЖЬ
| ИЛИ ЗаказПокупателя.Контрагент = &Контрагент) КАК РегистрНакопленияЗаказыПокупателейОстатки
20. user1126480 21 25.11.23 21:27 Сейчас в теме
(19) получилось:

|ИЗ
| РегистрНакопления.ЗаказыПокупателей.Остатки(
| ,
| (&ОтборПоКонтрагенту = ЛОЖЬ
| ИЛИ ЗаказПокупателя.Контрагент = &Контрагент)
| И (&ОтборПоОрганизации = ЛОЖЬ
| ИЛИ ЗаказПокупателя.Организация = &Организация)
| И (&ОтборПоПодразделениюОрганизации = ЛОЖЬ
| ИЛИ ЗаказПокупателя.СтруктурнаяЕдиницаПродажи = &ПодразделениеОрганизации)) КАК РегистрНакопленияЗаказыПокупателейОстатки
21. user1126480 21 06.02.24 13:04 Сейчас в теме
Почему не добавили второй параметр, что б получился рабочий вариант?

Работать будет так:

ГДЕ (&ОтборПоОрганизации = ЛОЖЬ ИЛИ Док.Организация = &Организация)

.........

ОтборПоОрганизации = ЗначениеЗаполнено(Организация);
Запрос.УстановитьПараметр("ОтборПоОрганизации", ОтборПоОрганизации);
Запрос.УстановитьПараметр("Организация", Организация);
Оставьте свое сообщение