Запрос: Получение узлового заказа покупателя из структуры подчиненности документов (УТ 10.3)

29.03.17

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

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

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

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

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

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

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

Запрос опробован и полностью подходит для встраивания в СКД.

ВЫБРАТЬ
	ПТУ.Ссылка КАК Ссылка,
	ПТУ.Сделка КАК ПервоеОснование
ПОМЕСТИТЬ ПервыеОснования
ИЗ
	Документ.ПоступлениеТоваровУслуг КАК ПТУ

ОБЪЕДИНИТЬ ВСЕ

ВЫБРАТЬ
	РТУ.Ссылка,
	РТУ.Сделка
ИЗ
	Документ.РеализацияТоваровУслуг КАК РТУ

ОБЪЕДИНИТЬ ВСЕ

ВЫБРАТЬ
	ВПок.Ссылка,
	ВПок.Сделка
ИЗ
	Документ.ВозвратТоваровОтПокупателя КАК ВПок

ОБЪЕДИНИТЬ ВСЕ

ВЫБРАТЬ
	СТ.Ссылка,
	СТ.Претензия
ИЗ
	Документ.СписаниеТоваров КАК СТ

ОБЪЕДИНИТЬ ВСЕ

ВЫБРАТЬ
	ОТов.Ссылка,
	""
ИЗ
	Документ.ОприходованиеТоваров КАК ОТов

ОБЪЕДИНИТЬ ВСЕ

ВЫБРАТЬ
	ВТПост.Ссылка,
	ВТПост.Сделка
ИЗ
	Документ.ВозвратТоваровПоставщику КАК ВТПост

ОБЪЕДИНИТЬ ВСЕ

ВЫБРАТЬ
	РТО.Ссылка,
	РТО.ДокументПеремещения
ИЗ
	Документ.РасходныйОрдерНаТовары КАК РТО

ОБЪЕДИНИТЬ ВСЕ

ВЫБРАТЬ
	ПТО.Ссылка,
	ПТО.ДокументПеремещения
ИЗ
	Документ.ПриходныйОрдерНаТовары КАК ПТО

ОБЪЕДИНИТЬ ВСЕ

ВЫБРАТЬ
	Перемещение.Ссылка,
	Перемещение.ВнутреннийЗаказ
ИЗ
	Документ.ПеремещениеТоваров КАК Перемещение

ОБЪЕДИНИТЬ ВСЕ

ВЫБРАТЬ
	ВЗак.Ссылка,
	ВЗак.ДокументОснование
ИЗ
	Документ.ВнутреннийЗаказ КАК ВЗак

;

////////////////////////////////////////////////////////////////////////////////
ВЫБРАТЬ
	ПервыеОснования.Ссылка,
	ПервыеОснования.ПервоеОснование,
	ВЫБОР
		КОГДА ТИПЗНАЧЕНИЯ(ПервыеОснования.ПервоеОснование) = ТИП(Документ.ЗаказПокупателя)
			ТОГДА ИСТИНА
		ИНАЧЕ ЛОЖЬ
	КОНЕЦ КАК ЭтоЗаказ
ПОМЕСТИТЬ ПолныйЖурнал
ИЗ
	ПервыеОснования КАК ПервыеОснования
;

////////////////////////////////////////////////////////////////////////////////
ВЫБРАТЬ
	ПолныйЖурнал.Ссылка,
	ВЫБОР
		КОГДА ПолныйЖурнал.ЭтоЗаказ
			ТОГДА ПолныйЖурнал.ПервоеОснование
		ИНАЧЕ ВЫБОР
				КОГДА ПолныйЖурналОснований.ЭтоЗаказ
					ТОГДА ПолныйЖурналОснований.ПервоеОснование
				ИНАЧЕ ВЫБОР
						КОГДА ПолныйЖурналОснований2.ЭтоЗаказ
							ТОГДА ПолныйЖурналОснований2.ПервоеОснование
						ИНАЧЕ NULL
					КОНЕЦ
			КОНЕЦ
	КОНЕЦ КАК ЗаказПокупателя
ПОМЕСТИТЬ ЖурналДокументов
ИЗ
	ПолныйЖурнал КАК ПолныйЖурнал
		ЛЕВОЕ СОЕДИНЕНИЕ ПолныйЖурнал КАК ПолныйЖурналОснований
		ПО ПолныйЖурнал.ПервоеОснование = ПолныйЖурналОснований.Ссылка
		ЛЕВОЕ СОЕДИНЕНИЕ ПолныйЖурнал КАК ПолныйЖурналОснований2
		ПО (ПолныйЖурналОснований.ПервоеОснование = ПолныйЖурналОснований2.Ссылка)
		ЛЕВОЕ СОЕДИНЕНИЕ ПолныйЖурнал КАК ПолныйЖурналОснований3
		ПО (ПолныйЖурналОснований2.ПервоеОснование = ПолныйЖурналОснований3.Ссылка)
;

////////////////////////////////////////////////////////////////////////////////
ВЫБРАТЬ
	ЖурналДокументов.Ссылка,
	МАКСИМУМ(ЕСТЬNULL(ЖурналДокументов.ЗаказПокупателя, 0)) КАК ЗаказПокупателя
ПОМЕСТИТЬ Заказы
ИЗ
	ЖурналДокументов КАК ЖурналДокументов

СГРУППИРОВАТЬ ПО
	ЖурналДокументов.Ссылка
;

////////////////////////////////////////////////////////////////////////////////
ВЫБРАТЬ
	ТоварыНаСкладах.Склад,
	Заказы.ЗаказПокупателя КАК Заказ,
	ТоварыНаСкладах.Регистратор,
	ТоварыНаСкладах.Номенклатура,
	ТоварыНаСкладах.КоличествоНачальныйОстаток КАК НачальныйОстаток,
	ТоварыНаСкладах.КоличествоПриход КАК Приход,
	ТоварыНаСкладах.КоличествоРасход КАК Расход,
	ТоварыНаСкладах.КоличествоКонечныйОстаток КАК КонечныйОстаток
ИЗ
	РегистрНакопления.ТоварыНаСкладах.ОстаткиИОбороты(&НачалоПериода, &КонецПериода, Регистратор, , ) КАК ТоварыНаСкладах
		ЛЕВОЕ СОЕДИНЕНИЕ Заказы КАК Заказы
		ПО (Заказы.Ссылка = ТоварыНаСкладах.Регистратор)

Запрос

См. также

SALE! 20%

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

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

Набор инструментов программиста и специалиста 1С для всех конфигураций на управляемых формах. В состав входят инструменты: Консоль запросов, Консоль СКД, Консоль кода, Редактор объекта, Анализ прав доступа, Метаданные, Поиск ссылок, Сравнение объектов, Все функции, Подписки на события и др. Редактор запросов и кода с раскраской и контекстной подсказкой. Доработанный конструктор запросов тонкого клиента. Продукт хорошо оптимизирован и обладает самым широким функционалом среди всех инструментов, представленных на рынке.

13000 10400 руб.

02.09.2020    122178    670    389    

714

Для чего используют конструкцию запроса "ГДЕ ЛОЖЬ" в СКД на примере конфигурации 1С:ERP

Запросы СКД Платформа 1С v8.3 Запросы Система компоновки данных 1С:ERP Управление предприятием 2 Бесплатно (free)

В типовых конфигурациях разработчики компании 1С иногда используют в отчетах, построенных на СКД, такую конструкцию, как "ГДЕ ЛОЖЬ". Такая конструкция говорит о том, что данные в запросе не будут получены совсем. Для чего же нужен тогда запрос?

13.02.2024    5746    KawaNoNeko    23    

23

Набор-объект для СКД по тексту или запросу

Запросы СКД Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Абонемент ($m)

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

1 стартмани

31.01.2024    2000    2    Yashazz    0    

29

Запрос 1С copilot

Инструментарий разработчика Запросы Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Абонемент ($m)

Пишем на человеческом языке, что нам надо, и получаем текст запроса на языке 1С. Используются большие языковые модели (LLM GPT) от OpenAI или Яндекс на выбор.

5 стартмани

15.01.2024    6286    31    mkalimulin    25    

50

PrintWizard: поддержка представлений ЗУП в конструкторе

Инструментарий разработчика Запросы Платформа 1С v8.3 Бесплатно (free)

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

14.12.2023    1742    vandalsvq    7    

29

Объектная модель запроса "Схема запроса" 2

Запросы Платформа 1С v8.3 Запросы Конфигурации 1cv8 Бесплатно (free)

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

06.12.2023    5388    user1923546    26    

43

Начните уже использовать хранилище запросов

HighLoad оптимизация Запросы

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

11.10.2023    16186    skovpin_sa    14    

98
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. dmitrichenko.ivan 6 29.03.17 14:22 Сейчас в теме
В запросе выбираются все документы?
2. KazanKokos 10 29.03.17 14:33 Сейчас в теме
(1) какие объедините в верхней времтаблице такие и будут. причем если из документа две ссылки вверх (допустим документоснование и заказпокупателя) то его туда надо два раза включать меняя второе поле. Выборка на удивление быстро происходит(у меня база очень большая). секунда две
3. slawa 26 30.03.17 14:59 Сейчас в теме
(0) Почему не используете критерии отбора?
4. KazanKokos 10 30.03.17 15:31 Сейчас в теме
(3) а какая разница? Запрос по всему журналу документов(довольно массивному) за секунду проходит. И критерии отбора не отменяют поиск по всем группировка структуры подчиненности вверх. Да и через критерии обмена это не нужно оказалось. Выложил просто как фишку работы с запросом
5. German_Tagil 42 06.04.17 09:10 Сейчас в теме
(4)Поставил ЗаказПоставщику вместо ЗаказПокупателя и как-то не понятно - отбор по заказпоставщику нормальный за период не удалось сделать
те мысль была приспособить данный запрос для отбора по ЗаказПоставщику
6. KazanKokos 10 06.04.17 11:09 Сейчас в теме
(5)
Тут меняете:
КОГДА ТИПЗНАЧЕНИЯ(ПервыеОснования.ПервоеОснование) = ТИП(Документ.ЗаказПокупателя)


тут псевдоним надо поменять:
1.
К
ОГДА ПолныйЖурналОснований2.ЭтоЗаказ
							ТОГДА ПолныйЖурналОснований2.ПервоеОснование
						ИНАЧЕ NULL
					КОНЕЦ
			КОНЕЦ
	КОНЕЦ КАК ЗаказПокупателя

2.
МАКСИМУМ(ЕСТЬNULL(ЖурналДокументов.ЗаказПокупателя, 0)) КАК ЗаказПокупателя

3.
 Заказы.ЗаказПокупателя КАК Заказ 



в принципе должно взлететь.
При этом:
1. В первой временной таблице указать(дообъединить) все поля из которых по цепочке можно вытащить основание.
2. Поиск по этим полям идет вверх по узлам. И если ЗаказПоставщику какого-то регистратора находится в параллельной ветке. То его не вытащить. Можно в принципе подумать как переделать запрос чтобы он вытаскивал от любой ветки всю структуру подчиненности в виде дерева а не только шел последовательно от узла к узлу вверх.

3. Ну и если вы идете конкретно по регистрам данных поставщиков то в любом случае должны до ЗПоставщику дойти
7. KazanKokos 10 06.04.17 11:10 Сейчас в теме
(5)

киньте запрос посмотрю. и какая конфа?
8. German_Tagil 42 06.04.17 14:22 Сейчас в теме
запрос счас скину конфа КА 1.1
9. German_Tagil 42 06.04.17 14:24 Сейчас в теме
ВЫБРАТЬ
	ПТУ.Ссылка КАК Ссылка,
	ПТУ.Сделка КАК ПервоеОснование
ПОМЕСТИТЬ ПервыеОснования
ИЗ
	Документ.ПоступлениеТоваровУслуг КАК ПТУ

ОБЪЕДИНИТЬ ВСЕ

ВЫБРАТЬ
	РТУ.Ссылка,
	РТУ.Сделка
ИЗ
	Документ.РеализацияТоваровУслуг КАК РТУ

ОБЪЕДИНИТЬ ВСЕ

ВЫБРАТЬ
	ВПок.Ссылка,
	ВПок.Сделка
ИЗ
	Документ.ВозвратТоваровОтПокупателя КАК ВПок

ОБЪЕДИНИТЬ ВСЕ

ВЫБРАТЬ
	ОТов.Ссылка,
	""
ИЗ
	Документ.ОприходованиеТоваров КАК ОТов

ОБЪЕДИНИТЬ ВСЕ

ВЫБРАТЬ
	ВТПост.Ссылка,
	ВТПост.Сделка
ИЗ
	Документ.ВозвратТоваровПоставщику КАК ВТПост

ОБЪЕДИНИТЬ ВСЕ

ВЫБРАТЬ
	ПТО.Ссылка,
	ПТО.ДокументПеремещения
ИЗ
	Документ.ПриходныйОрдерНаТовары КАК ПТО

ОБЪЕДИНИТЬ ВСЕ

ВЫБРАТЬ
	Перемещение.Ссылка,
	Перемещение.ВнутреннийЗаказ
ИЗ
	Документ.ПеремещениеТоваров КАК Перемещение

ОБЪЕДИНИТЬ ВСЕ

ВЫБРАТЬ
	ВЗак.Ссылка,
	ВЗак.ДокументОснование
ИЗ
	Документ.ВнутреннийЗаказ КАК ВЗак
;

////////////////////////////////////////////////////////////­////////////////////
ВЫБРАТЬ
	ПервыеОснования.Ссылка,
	ПервыеОснования.ПервоеОснование,
	ВЫБОР
		КОГДА ТИПЗНАЧЕНИЯ(ПервыеОснования.ПервоеОснование) = ТИП(Документ.ЗаказПоставщику)
			ТОГДА ИСТИНА
		ИНАЧЕ ЛОЖЬ
	КОНЕЦ КАК ЭтоЗаказ
ПОМЕСТИТЬ ПолныйЖурнал
ИЗ
	ПервыеОснования КАК ПервыеОснования
;

////////////////////////////////////////////////////////////­////////////////////
ВЫБРАТЬ
	ПолныйЖурнал.Ссылка,
	ВЫБОР
		КОГДА ПолныйЖурнал.ЭтоЗаказ
			ТОГДА ПолныйЖурнал.ПервоеОснование
		ИНАЧЕ ВЫБОР
				КОГДА ПолныйЖурналОснований.ЭтоЗаказ
					ТОГДА ПолныйЖурналОснований.ПервоеОснование
				ИНАЧЕ ВЫБОР
						КОГДА ПолныйЖурналОснований2.ЭтоЗаказ
							ТОГДА ПолныйЖурналОснований2.ПервоеОснование
						ИНАЧЕ NULL
					КОНЕЦ
			КОНЕЦ
	КОНЕЦ КАК ЗаказПоставщику
ПОМЕСТИТЬ ЖурналДокументов
ИЗ
	ПолныйЖурнал КАК ПолныйЖурнал
		ЛЕВОЕ СОЕДИНЕНИЕ ПолныйЖурнал КАК ПолныйЖурналОснований
		ПО ПолныйЖурнал.ПервоеОснование = ПолныйЖурналОснований.Ссылка
		ЛЕВОЕ СОЕДИНЕНИЕ ПолныйЖурнал КАК ПолныйЖурналОснований2
		ПО (ПолныйЖурналОснований.ПервоеОснование = ПолныйЖурналОснований2.Ссылка)
		ЛЕВОЕ СОЕДИНЕНИЕ ПолныйЖурнал КАК ПолныйЖурналОснований3
		ПО (ПолныйЖурналОснований2.ПервоеОснование = ПолныйЖурналОснований3.Ссылка)
;

////////////////////////////////////////////////////////////­////////////////////
ВЫБРАТЬ
	ЖурналДокументов.Ссылка,
	МАКСИМУМ(ЕСТЬNULL(ЖурналДокументов.ЗаказПоставщику, 0)) КАК ЗаказПоставщику
ПОМЕСТИТЬ Заказы
ИЗ
	ЖурналДокументов КАК ЖурналДокументов

СГРУППИРОВАТЬ ПО
	ЖурналДокументов.Ссылка
;

////////////////////////////////////////////////////////////­////////////////////
ВЫБРАТЬ
	ТоварыНаСкладах.Склад,
	Заказы.ЗаказПоставщику КАК Заказ,
	ТоварыНаСкладах.Регистратор,
	ТоварыНаСкладах.Номенклатура,
	ТоварыНаСкладах.КоличествоНачальныйОстаток КАК НачальныйОстаток,
	ТоварыНаСкладах.КоличествоПриход КАК Приход,
	ТоварыНаСкладах.КоличествоРасход КАК Расход,
	ТоварыНаСкладах.КоличествоКонечныйОстаток КАК КонечныйОстаток
ИЗ
	РегистрНакопления.ТоварыНаСкладах.ОстаткиИОбороты(&НачалоПериода, &КонецПериода, Регистратор, , ) КАК ТоварыНаСкладах
		ЛЕВОЕ СОЕДИНЕНИЕ Заказы КАК Заказы
		ПО (Заказы.Ссылка = ТоварыНаСкладах.Регистратор)
ГДЕ
	НЕ Заказы.Ссылка Есть NULL
Показать
10. KazanKokos 10 06.04.17 14:47 Сейчас в теме
Не получится. Вам по любому тогда надо переходить на соседнюю ветку. это надо запрос переделывать. У вас заказ поставщику всплывет только на приходных операциях когда от него есть прямая ссылка от ПТУ. Надо переделать запрос так:
Оставить запрос темы как есть и вытаскивать корневой ЗаказПокупателя. Потом делать выборку заказов поставщику(без периодов) и такимже запросом вытаскивать Заказ покупателя(если конечно заказпоставщику у вас в структуре) и по нему уже вязать соединением две временные таблицы.
11. KazanKokos 10 06.04.17 14:50 Сейчас в теме
ну и часто заказпоставщику содержит в себе ссылки на заказпокупателя по которому делается заказ(в типов в тч Товары, либо часто сами привязывают в Заказупокупателя)и вытаскивать этот заказ и понему вязать
12. German_Tagil 42 24.05.18 20:37 Сейчас в теме
Оставьте свое сообщение