• 15 апреля стартует «Курс «SQL-injection Master» ©» от команды The Codeby

    За 3 месяца вы пройдете путь от начальных навыков работы с SQL-запросами к базам данных до продвинутых техник. Научитесь находить уязвимости связанные с базами данных, и внедрять произвольный SQL-код в уязвимые приложения.

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

    Запись на курс до 25 апреля. Получить промодоступ ...

Вопрос по Естьnull

  • Автор темы Sangitam
  • Дата начала
S

Sangitam

Почему запрос1 формирует остатки по складу, в т.ч. нулевые, а запрос2 только ненулевые?


Запрос1.Текст =
"ВЫБРАТЬ
| Номенклатура.Ссылка,
| NULL КАК КоличествоОстаток
|ИЗ
| Справочник.Номенклатура КАК Номенклатура
|
|ОБЪЕДИНИТЬ ВСЕ
|
|ВЫБРАТЬ
| ТоварыНаСкладахОстатки.Номенклатура.Ссылка,
| ЕСТЬNULL(ТоварыНаСкладахОстатки.КоличествоОстаток, 0)
|ИЗ
| РегистрНакопления.ТоварыНаСкладах.Остатки КАК ТоварыНаСкладахОстатки
|ГДЕ
| ТоварыНаСкладахОстатки.Склад.Ссылка = &ВыбСклад";
СпрСклад = Справочники.Склады.НайтиПоКоду("000000009");
Запрос1.УстановитьПараметр("ВыбСклад",СпрСклад);



Запрос2.Текст =
"ВЫБРАТЬ
| ЦеныНоменклатурыСрезПоследних.Номенклатура.Ссылка,
| NULL КАК КоличествоОстаток,
| ЦеныНоменклатурыСрезПоследних.ТипЦен.Ссылка,
| ЦеныНоменклатурыСрезПоследних.ТипЦен.ВалютаЦены.Наименование,
| ЦеныНоменклатурыСрезПоследних.ЕдиницаИзмерения.Ссылка,
| ЦеныНоменклатурыСрезПоследних.Цена
|ИЗ
| РегистрСведений.ЦеныНоменклатуры.СрезПоследних КАК ЦеныНоменклатурыСрезПоследних
|ГДЕ
| ЦеныНоменклатурыСрезПоследних.ТипЦен.Ссылка = &Некондиция
|
|ОБЪЕДИНИТЬ ВСЕ
|
|ВЫБРАТЬ
| ТоварыНаСкладахОстатки.Номенклатура.Ссылка,
| ЕСТЬNULL(ТоварыНаСкладахОстатки.КоличествоОстаток, 0),
| NULL,
| NULL,
| NULL,
| NULL
|ИЗ
| РегистрНакопления.ТоварыНаСкладах.Остатки КАК ТоварыНаСкладахОстатки
|ГДЕ
| ТоварыНаСкладахОстатки.Склад.Ссылка = &ВыбСклад";
СпрТипыЦен2 = Справочники.ТипыЦенНоменклатуры.НайтиПоНаименованию("Некондиция");
Запрос2.УстановитьПараметр("Некондиция",СпрТипыЦен2);
СпрСклад = Справочники.Склады.НайтиПоКоду("000000009");
Запрос2.УстановитьПараметр("ВыбСклад",СпрСклад);
 
U

unknown181538

М.. даж не знаю, как объяснить...
Попробуйте сами понять как формируется результат запроса.

Первый - выбирает все записи справочникаи добавляет к ним записи из таблицы остатков.

Второй объединяет все записи регистра сведений со всеми остатками, которые есть...
 
Мы в соцсетях:

Обучение наступательной кибербезопасности в игровой форме. Начать игру!