ВЫРАЗИТЬ в запросах 1С 8.3 — применение на примерах
Оператор «ВЫРАЗИТЬ» в языке запросов 1С 8.3 используют в двух случаях:
- Когда необходимо преобразовать строковый или числовой тип данных к нужному виду (формату)
- Для выделения одного типа, в полях выборки имеющих составной тип данных.
Рассмотрим на примерах работу такого оператора.
Содержание
ВЫРАЗИТЬ КАК Строка
Для работы со строковым типом данных такой оператор может пригодиться, когда необходимо жёстко задать размерность строки.
Синтаксис:
ВЫРАЗИТЬ(<Выражение> КАК Строка(<ДлинаСтроки>))
Наша команда предоставляет услуги по консультированию, настройке и внедрению 1С.
Связаться с нами можно по телефону +7 499 350 29 00.
Услуги и цены можно увидеть по ссылке.
Будем рады помочь Вам!
Пример:
ВЫБРАТЬ
ВЫРАЗИТЬ(Номенклатура.Наименование КАК Строка(1)) КАК НаименованиеДлина_1
ИЗ
Справочник.Номенклатура КАК Номенклатура
В таком примере выбираем все наименования из справочника «Номенклатура», затем с помощью конструкции «ВЫРАЗИТЬ» совместно с оператором «Строка», ограничиваем размер строки поля выборки до одного символа.
ВЫРАЗИТЬ КАК Число
В полях выборки запроса имеющих числовой тип данных, с помощью оператора «ВЫРАЗИТЬ» возможно, контролировать длину целой и дробной части числа. В случаях, когда в результате такого контроля будет уменьшено количество знаков в числе, произойдёт округление по математическим правилам.
Синтаксис:
Получите понятные самоучители по 1С бесплатно:
ВЫРАЗИТЬ(<Выражение> КАК Число(<ДлинаЦелойЧасти>.<ДлинаДробнойЧасти>))
Пример№1:
ВЫБРАТЬ
3.55 КАК НашеЧисло,
ВЫРАЗИТЬ(3.55 КАК Число(15,1)) КАК РезультатОкругления
Результат:
Пример№2:
ВЫБРАТЬ
10/3 КАК Результат,
ВЫРАЗИТЬ(10/3 КАК Число(15,2)) КАК РезультатОкругления
Результат:
Глядя на результаты примеров понятно, что оператор «ВЫРАЗИТЬ» округляет числа по правилу «до ближайшего целого».
«ВЫРАЗИТЬ» для составного типа данных и оптимизация запросов
С помощью оператора «ВЫРАЗИТЬ», для в полей имеющих составной тип данных, возможно ограничить попадание значений которые не соответствуют определённому типу данных. Причём такие ограничения можно сделать ещё на этапе выборки данных. Такие действия приводят к неявной оптимизации запросов. Рассмотрим подробно на примере.
Есть запрос, который выбирает всех покупателей, из существующих в базе документов «ПродажаТоваров». У документов такого вида реквизит «Покупатель» имеет составной тип данных:
- <СправочникСсылка.Контрагенты>
- <СправочникСсылка.Сотрудники>.
Запрос:
ВЫБРАТЬ
ПродажаТоваров.Ссылка КАК СсылкаНаДокументПродажи,
ПродажаТоваров.Покупатель КАК СсылкаНаПокупателя
ИЗ
Документ.ПродажаТоваров КАК ПродажаТоваров
Результат:
Следует понимать, что данные в поле «СсылкаНаПокупателя» формируются путём неявного левого соединения с таблицами «Контрагенты.Ссылка» из справочника «Контраенты» и «Сотрудники.Ссылка» из справочника «Сотрудники». Такие соединения в запросах 1С происходят, когда мы обращаемся к подчинённому полю через точку (разыменовываем поле). В нашем случае мы обращаемся к полю «Покупатель».
Визуальное представление работы такого запроса:
Если бы стояла задача отобрать только те документы, в которых покупателем был сотрудник. То наиболее оптимальным решением с точки зрения скорости выполнения запроса было бы вовсе запретить обращаться к справочнику «Контрагенты» так как данные из этого справочника для нас излишни. С такой задачей легко справится оператор «ВЫРАЗИТЬ» и запрос мог бы выглядеть так:
Запрос:
ВЫБРАТЬ
ПродажаТоваров.Ссылка КАК СсылкаНаДокументПродажи,
ВЫРАЗИТЬ(ПродажаТоваров.Покупатель КАК Справочник.Сотрудники) КАК СсылкаНаПокупателя
ИЗ
Документ.ПродажаТоваров КАК ПродажаТоваров
Результат:
Однако, как мы можем видеть из результата запроса, поля выборки, которые не удовлетворяют условиям нашего отбора, получили значения «NULL». По этому реализуя отборы с помощью конструкции «ВЫРАЗИТЬ» во избежание дальнейших ошибок правильно накладывать дополнительное условие, например с помощью оператора «Где». Тогда запрос мог бы выглядеть так:
Запрос:
ВЫБРАТЬ
ПродажаТоваров.Ссылка КАК СсылкаНаДокументПродажи,
ВЫРАЗИТЬ(ПродажаТоваров.Покупатель КАК Справочник.Сотрудники) КАК СсылкаНаПокупателя
ИЗ
Документ.ПродажаТоваров КАК ПродажаТоваров
Где
ПродажаТоваров.Покупатель ССЫЛКА Справочник.Сотрудники
Результат:
Возможные ошибки
С помощью оператора «ВЫРАЗИТЬ» не представляется возможным преобразование типов данных. Например, строку в число:
ВЫБРАТЬ
ВЫРАЗИТЬ(«123» КАК Число(15,2)) КАК Число
При выполнении такого запроса неизбежно получим следующую ошибку:
Комментарии
Если мы напишем
«Где
ПродажаТоваров.Покупатель ССЫЛКА Справочник.Сотрудники»
То зачем нам вообще ВЫРАЗИТЬ? И так отберётся только нужное.
Здесь вопрос не в том что получить, а в том как запрос оптимизировать.