Естьnull в запросе. Значения null (есть null и естьnull()) Проверка на null в запросе 1с 8.3

02.06.2021

27.06.2017

NULL, ЕСТЬNULL() и ЕСТЬ NULL в запросах 1С

Что такое NULL

NULL в результате запроса, означает отсутствие значения (это не пустое значение, не нулевое, не пустая ссылка).
Например в результате соединения таблиц запроса, не нашлось значения в одной из таблиц при связи по полям соединения. Или в запросе идет обращение к несуществующему реквизиту (свойству).

NULL не равно NULL !

Если вы в запросе 1С захотите наложить отбор (условие) с проверкой на NULL, то конструкция вида " ГДЕ ВТ.Поле1 = NULL" Всегда будет возвращать ЛОЖЬ ! Для проверки следует использовать специальный оператор

ЕСТЬ NULL в запросе 1С

Для проверки значения (или для работы со значениями) на NULL необходимо использовать следующую конструкцию " ГДЕ ВТ.Поле1 ЕСТЬ NULL" Или другой пример, использование в конструкции ВЫБОР " ВЫБОР | КОГДА ВТ.Поле1 ЕСТЬ NULL | ТОГДА" Стоит отметить, что функция проверки поля на NULL одна из самых ресурсоемких в запросах 1С. Поэтому если Вы хотите использовать ее в условии запроса, подумайте, возможно ли заменить такую проверку внутренним соединением (вид соединения в запросах, при котором в выборке остаются только записи, присутствующие в обоих таблицах).

Функция ЕСТЬNULL() в запросе 1С

Функция ЕСТЬNULL() позволяет заменить отсутствующее значение в поле запроса, на указанное значение (стандартное значение, заглушку).
К примеру, если информация о стоимости товара отсутствует, то мы указываем ее равной 0 (нулю) "ВЫБРАТЬ | ЕСТЬNULL(ВТ.Цена, 0) КАК Цена |ИЗ ОстаткиТоваров КАК ВТ"

Заключение

Пишите запросы правильно и оптимально. Потому что плохой запрос - это тормоза и говнокод)

NULL – отсутствующие значения.
Не путать с нулевым значением! NULL – это не число, не равно пробелу, пустой ссылке, Неопределено.

NULL – типообразующее значение, т.е. есть тип NULL и единственное значение этого типа.

NULL значения появляются в запросе в следующих ситуациях:
а) Внешнее соединение, при котором не было найдено соответствующей записи в другой таблице (при левом – во второй, при правом – в первой, при полном – в обоих)
б) Обращение к реквизитам элементов для группы и наоборот.
в) NULL в списке полей выборки (ВЫБРАТЬ)
г) Обращение к реквизитам для битой ссылки

ЕСТЬ NULL используется в операторе ВЫБРАТЬ (как бы проверя, что значение это есть пустое (Значение ЕСТЬ NULL)):
Код 1C v 8.х
ВЫБОР
КОГДА Значение ЕСТЬ NULL ТОГДА РезультатЕслиNULL
ИНАЧЕ Значение
КОНЕЦ

еще пример:
Код 1C v 8.х ВЫБРАТЬ

ВЫБОР КОГДА УчетНоменклатурыОстатки.КоличествоОстаток ЕСТЬ NULL ТОГДА 0
ИНАЧЕ УчетНоменклатурыОстатки.КоличествоОстаток КАК КоличествоОстаток
ИЗ



ГДЕ

Функция ЕСТЬNULL (значение, РезультатЕслиNULL) возвращает значение своего первого параметра, в случае если он не равен NULL, и значение второго параметра в противном случае
Является свернутым ВЫБОР…КОНЕЦ, но ЕСТЬNULL предпочтительнее.
Код 1C v 8.х
ВЫБРАТЬ
ЕСТЬNULL(Справочник.Номенклатура.Артикул, "---") КАК Артикул,
Справочник.Номенклатура.Представление КАК Номенклатура

еще пример:
Код 1C v 8.х
ВЫБРАТЬ
СправочникНоменклатуры.Наименование,
ЕСТЬNULL(УчетНоменклатурыОстатки.КоличествоОстаток, 0) КАК КоличествоОстаток
ИЗ
Справочник.Номенклатура КАК СправочникНоменклатуры
ЛЕВОЕ СОЕДИНЕНИЕ РегистрНакопления.УчетНоменклатуры.Остатки КАК УчетНоменклатурыОстатки
ПО УчетНоменклатурыОстатки.Номенклатура = СправочникНоменклатуры.Ссылка
ГДЕ
СправочникНоменклатуры.ЭтоГруппа = ЛОЖЬ
В данном примере получаются все элементы справочника номенклатуры, после чего, для каждой номенклатуры из регистра накопления получаются текущие остатки. Т.к. для номенклатуры, по которой отсутствуют остатки, виртуальная таблица остатков не запись вернет, то в результате соединения в поле "УчетНоменклатурыОстатки.КоличествоОстаток" будут значения NULL для номенклатуры, по которой не было остатков. Для того чтобы вместо значения NULL в результате запроса присутствовало значение 0, мы использовали функцию ЕСТЬNULL(), которая осуществит желаемую замену.

ЕСТЬNULL отличается от ВЫБОР по следующим причинам:
а) При ЕСТЬNULL лучше читается запрос (проще)
б) При ЕСТЬNULL, если проверяется сложное выражение, то работает быстрее, поскольку вычисляется один раз
в) При ЕСТЬNULL выражение замены приводится к типу проверяемого выражения, если оно имеет тип Строка (длина) или Число (разрядность).

Нельзя проверять значения на NULL обычным равенством, потому что в SQL действует трехзначная логика – Истина, Ложь, NULL, и результатом такого сравнения будет UNKNOWN, что в 1С 8.0 аналогично ЛОЖЬ.
NULL <> 0, поэтому при левых внешних соединениях спр. Номенклатура с таблицами остатков, цен, Контрагентов со взаиморасчетами при отсутствии таких записей там будет NULL, который не равен 0. Лучшее решение – ЕСТЬNULL

Функция ЕСТЬNULL(английский синоним ISNULL) используется для подмены нулевого(отсутствующего) значения при соединениях таблиц. Таблицы могут быть произвольными (как совпадающими по полям).

Null — это не число 0, а именно отсутствующее значение.

Наиболее частое использование данной функции для подмены параметры функции Сумма() на 0, передача пустого значения может не вызывать ошибки исполнения, но приводить к некорректному результату, особенно при использовании в запросах СКД.

Быстрый переход

Результат ее выполнения:

  • Значение определенного типа, если оно существует.
  • Указанное вторым параметром значение (любого типа).

Синтаксис ISNULL

ЕстьNULL(<ПроверяемоеПоле>,<ЗначениеЗамены>)

Аналогом этой функции может быть конструкция:
ВЫБОР
КОГДА Таблица.Поле1 ЕСТЬ NULL ТОГДА "Некое значение"
ИНАЧЕ
Таблица.Поле1
КОНЕЦ

Как на практике используется ЕстьNULL

1. Подмена значения константой
ЕСТЬNULL(Таблица1.Поле1,"Некое значение")

ЕСТЬNULL(Таблица1.Количество, 0)

2. Подмена значения параметром

ЕСТЬNULL(Таблица1.Поле1,&Параметр)

3. Подмена значением из другой таблицы

ЕСТЬNULL (Таблица1.Поле1,Таблица2.Поле1)

4.Использование функции для получения предопределенного или пустого значения

ЕСТЬNULL(Таблица2.Поле1,ЗНАЧЕНИЕ(Справочник.Контрагенты.ПустаяСсылка))

Здравствуйте.
В продолжение о примитивных типах данных, так недавно рассматривали , а сегодня поговорим о типе NULL .

Тип NULL – литерал, в котором может содержаться лишь одно значение это значение «NULL».
NULL — Не равен пустой ссылке, пробелу или Типу Неопределено.

Применяется при работе с БД (при соединении таблиц), используется для определения отсутствующего значения при работе с БД.
Значение типа NULL можно получить присвоив переменной это значение:
Переменная =NULL.

Значения типа NULL образуются в результате соединений когда элементу из одной таблицы по условию не находится соответствующего элемента из другой. Значение типа NULL имею специфические особенности:
— сравнение значения NULL с любым другим аргументом всегда возвращает ложь;

Для определения значения NULL используется конструкция ЕСТЬ NULL (is NULL) .
Для преобразования типа NULL используется функция ЕСТЬNULL (isNULL) .

Для того, чтобы в результате запроса отсечь поля, содержащие значения NULL применяются следующие конструкции: — is not NULL — not is NULL

Примеры

Пример проверки значения на NULL

ВЫБРАТЬ Справочник. Номенклатура. Наименование, Справочник. Номенклатура. ЗакупочнаяЦена ГДЕ Справочник. Номенклатура. ЗакупочнаяЦена Есть NULL

Пример функции ЕСТЬNULL ()
Возвращаемое значение функции ЕСТЬNULL () : значение первого параметра, в случае, если первый параметр не содержит значение NULL, противном случае значение второго параметра. Второй параметр будет преобразован к типу первого параметра в случае, если тип первого параметра является строкой или числом.

// Получить сумму по полю количество. В случае, если нет записей, получить 0 ВЫБРАТЬ ЕСТЬNULL(СУММА(Количество), 0 ) КАК Количество ИЗ Документ. РасхНакл. Состав

С уважением 1С Программер.
Оставляйте свои комментарий, мне интересно ваше мнение.

© tuttiragazzi.ru, 2024
Портал о компьютерах и мобильных устройствах