Языком запросов разместить N яблок на складах с М ячеек

27.08.09

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

Как языком запросов разместить N яблок на складах с М ячеек.
UPD: размещение нескольких номенклатурных позиций на нескольких ячеистых складах
Написать статью побудила эта тема http://infostart.ru/blogs/1242/
ВЫБРАТЬ
"Вакуум 1" КАК Наименование,
10 КАК СвободныхЯчеек,
1 КАК Приоритет
ПОМЕСТИТЬ втСклады

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

ВЫБРАТЬ
"Вакуум 2",
20,
2

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

ВЫБРАТЬ
"Вакуум 3",
10,
3
;

////////////////////////////////////////////////////////////////////////////////
ВЫБРАТЬ
Склады.Наименование,
Склады.СвободныхЯчеек,
Склады.Приоритет КАК Приоритет,
ЕСТЬNULL(СУММА(СкладыЯчеек.СвободныхЯчеек), 0) + 1 КАК ПерваяЯчейка,
ЕСТЬNULL(СУММА(СкладыЯчеек.СвободныхЯчеек), 0) + Склады.СвободныхЯчеек КАК ПоследняяЯчейка
ПОМЕСТИТЬ втСкладыЯчейки
ИЗ
втСклады КАК Склады
ЛЕВОЕ СОЕДИНЕНИЕ втСклады КАК СкладыЯчеек
ПО (СкладыЯчеек.Приоритет < Склады.Приоритет)

СГРУППИРОВАТЬ ПО
Склады.Наименование,
Склады.СвободныхЯчеек,
Склады.Приоритет
;

////////////////////////////////////////////////////////////////////////////////
ВЫБРАТЬ
"Сферический конь 1" КАК Наименование,
25 КАК Количество,
1 КАК Приоритет
ПОМЕСТИТЬ втНоменклатура
ОБЪЕДИНИТЬ ВСЕ

ВЫБРАТЬ
"Сферический конь 2",
10,
2
;
////////////////////////////////////////////////////////////////////////////////
ВЫБРАТЬ
Номенклатура1.Наименование,
Номенклатура1.Приоритет КАК Приоритет,
ЕСТЬNULL(СУММА(Номенклатура2.Количество), 0) + 1 КАК ПерваяПозиция,
ЕСТЬNULL(СУММА(Номенклатура2.Количество), 0) + Номенклатура1.Количество КАК ПоследняяПозиция
ПОМЕСТИТЬ втНоменклатураПорядокРазмещения
ИЗ
втНоменклатура КАК Номенклатура1
ЛЕВОЕ СОЕДИНЕНИЕ втНоменклатура КАК Номенклатура2
ПО (Номенклатура2.Приоритет < Номенклатура1.Приоритет)

СГРУППИРОВАТЬ ПО
Номенклатура1.Наименование,
Номенклатура1.Количество,
Номенклатура1.Приоритет
;

////////////////////////////////////////////////////////////////////////////////
ВЫБРАТЬ
СкладЯчейки.Наименование КАК СкладНаименование,
Номенклатура.Наименование КАК НоменклатураНаименование,
ВЫБОР
КОГДА Номенклатура.ПерваяПозиция > СкладЯчейки.ПоследняяЯчейка
ТОГДА 0
КОГДА Номенклатура.ПоследняяПозиция < СкладЯчейки.ПерваяЯчейка
ТОГДА 0
КОГДА Номенклатура.ПоследняяПозиция >= СкладЯчейки.ПоследняяЯчейка
И Номенклатура.ПерваяПозиция ТОГДА СкладЯчейки.ПоследняяЯчейка - СкладЯчейки.ПерваяЯчейка + 1
КОГДА Номенклатура.ПоследняяПозиция >= СкладЯчейки.ПоследняяЯчейка
И Номенклатура.ПерваяПозиция > СкладЯчейки.ПерваяЯчейка
ТОГДА СкладЯчейки.ПоследняяЯчейка - Номенклатура.ПерваяПозиция + 1
КОГДА Номенклатура.ПоследняяПозиция < СкладЯчейки.ПоследняяЯчейка
И Номенклатура.ПерваяПозиция ТОГДА Номенклатура.ПоследняяПозиция - СкладЯчейки.ПерваяЯчейка + 1
КОГДА Номенклатура.ПоследняяПозиция < СкладЯчейки.ПоследняяЯчейка
И Номенклатура.ПерваяПозиция > СкладЯчейки.ПерваяЯчейка
ТОГДА Номенклатура.ПоследняяПозиция - Номенклатура.ПерваяПозиция + 1
ИНАЧЕ 0
КОНЕЦ КАК ЗанятоНоменклатурой
ИЗ
втСкладыЯчейки КАК СкладЯчейки,
втНоменклатураПорядокРазмещения КАК Номенклатура
ГДЕ
ВЫБОР
КОГДА Номенклатура.ПерваяПозиция > СкладЯчейки.ПоследняяЯчейка
ТОГДА 0
КОГДА Номенклатура.ПоследняяПозиция < СкладЯчейки.ПерваяЯчейка
ТОГДА 0
КОГДА Номенклатура.ПоследняяПозиция >= СкладЯчейки.ПоследняяЯчейка
И Номенклатура.ПерваяПозиция ТОГДА СкладЯчейки.ПоследняяЯчейка - СкладЯчейки.ПерваяЯчейка + 1
КОГДА Номенклатура.ПоследняяПозиция >= СкладЯчейки.ПоследняяЯчейка
И Номенклатура.ПерваяПозиция > СкладЯчейки.ПерваяЯчейка
ТОГДА СкладЯчейки.ПоследняяЯчейка - Номенклатура.ПерваяПозиция + 1
КОГДА Номенклатура.ПоследняяПозиция < СкладЯчейки.ПоследняяЯчейка
И Номенклатура.ПерваяПозиция ТОГДА Номенклатура.ПоследняяПозиция - СкладЯчейки.ПерваяЯчейка + 1
КОГДА Номенклатура.ПоследняяПозиция < СкладЯчейки.ПоследняяЯчейка
И Номенклатура.ПерваяПозиция > СкладЯчейки.ПерваяЯчейка
ТОГДА Номенклатура.ПоследняяПозиция - Номенклатура.ПерваяПозиция + 1
ИНАЧЕ 0
КОНЕЦ > 0

УПОРЯДОЧИТЬ ПО
СкладЯчейки.Приоритет,
Номенклатура.Приоритет

 

 

 

См. также

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

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

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

10000 руб.

02.09.2020    124638    681    389    

732

Пропорциональное распределение в запросе с использованием АвтоНомерЗаписи()

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

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

11.04.2024    2095    andrey_sag    10    

27

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

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

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

13.02.2024    5973    KawaNoNeko    23    

25

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

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

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

1 стартмани

31.01.2024    2139    2    Yashazz    0    

30

Запрос 1С copilot

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

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

5 стартмани

15.01.2024    6602    31    mkalimulin    27    

51

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

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

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

14.12.2023    1874    vandalsvq    7    

29

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

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

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

06.12.2023    5604    user1923546    26    

46

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

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

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

11.10.2023    16557    skovpin_sa    14    

101
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. bxz 417 27.08.09 12:30 Сейчас в теме
немного изменил: теперь размещается не одна номенклатура а несколько
+
2. serge_focus 4 31.03.12 02:03 Сейчас в теме
Спасибо за оригинальное решение ;)
+
3. CheBurator 3119 22.04.17 06:30 Сейчас в теме
ввиду отсутствия http://infostart.ru/blogs/1242/ - хорошо бы дать пояснения
+
Внимание! Тема сдана в архив