1с запрос текст в число

Встроенная функция запроса ВЫРАЗИТЬ() используется не только для приведения, но и для округления чисел.

Для этого используется такой синтаксис:

ВЫРАЗИТЬ( КАК ЧИСЛО ( . ))

Общие особенности использования в запросе

Если в качестве параметра передано не числовое значение, это может не вызывать ошибки выполнения запроса, но значение корректно не обработается:

Например, если передан NULL или он сформировался при соединениях таблиц, значение на выходе останется NULL:

Передача же «Неопределено» вызывает ошибку «Несовместимые типы ВЫРАЗИТЬ»:

  • Ссылочные типы или значения БУЛЕВО вызывают такую же ошибку (ИСТИНА не приводится к 1, а ЛОЖЬ к 0).
  • ВЫРАЗИТЬ строку как число также нельзя, используя эту функцию.

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

Обработка значения производится по методам округления (0.5 округляется до 1.0), поэтому, если требуется получить целое значение, то следует перед округлением вычесть 0.5 (половину цены шага)

Для округления до десятых в меньшую сторону вычесть 0.5, до сотых 0.05.

Демонстрация использования ВЫРАЗИТЬ в запросе для округления

Никакая реклама не поможет продать то, что продать невозможно.

МАКСИМУМ(выразить(Номенклатура.Код как число(6,2))) — к сожалению вот так преобразовать строку в число не получится!

На помощь придут вот такие функции. Нашел их тут.

Использовать их так:

Получаем максимальный числовой код для товара из спр Номенклатура, где код — строка:

  • Главная
  • В помощь 1с программисту
  • 1С Строку в число в запросе. Число в строку в запросе.

Google+

  • © 2019 Услуги 1С программиста. Доработка и обслуживание 1С. Удаленное программирование по всей России. Платформы 7.7 8.2 8.3 , битрикс.

    В этой статье разберем возможности приведения типов в языке запросов 1С, которые предоставляет функция «Выразить».
    Рассмотрим несколько вариантов применения этой функции.
    И первый вариант – округление чисел.

    Для этого необходимо использовать функцию Выразить в следующем формате:

    Выразить( как Число( , ))

    Где:
    Число — поле, параметр которое нужно округлить
    ДлинаЧисла — максимальная длина числа
    Точность — точность округления числа

    Параметры и длинна и точность должны быть целыми положительными числами.
    Посмотрите, как работает эта функция на рисунке ниже.

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

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

    Выразить( как Строка( )

    Где
    ДлинаСтроки – максимальная длина, к которой будет приведена строка.
    Переделаем запрос: будем в условии приводить неограниченную строку к строке с определенной длинной. Тогда ни каких ошибок не будет.

    Рассмотрим последний и, я бы сказал, самый главный вариант её применения: при работе с полями составного типа.
    Ниже приведены два запроса, в которых используются поля составного типа. Первый неправильный, а второй правильный.

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

    Выразить( как Документ. )
    Выразить( как Справочник. )
    .

    Где
    ИмяТаблицы — название объекта в конфигураторе 1С.

    Всегда используйте функцию выразить, когда работаете с составными типами, это существенно оптимизирует запрос.

    Если Вы всё еще «плаваете» в конструкциях языка запросов, и у Вас вызывают трудности даже самые простые запросы, то рекомендую вам мой курс «Запросы в 1С от новичка до профи». Где эти и многие другие вопросы рассматриваются более подробно.

    В чем особенность этого курса:
    • Курс рассчитан на тех, кто не знаком с языком запросов в 1С;
    • Учебный материал грамотно скомпонован и прост в освоении;
    • Несколько десятков уроков;
    • Полезные практические примеры;
    • Все уроки изложены понятным и простым языком

    Для моих читателей, купон на скидку 25%: hrW0rl9Nnx

    Я стараюсь как можно чаще выпускать различные интересные бесплатные статьи и видеоуроки. Поэтому буду очень рад, если Вы поддержите мой проект перечислив любую сумму:

    Можете перечислить любую сумму напрямую:
    Яндекс.Деньги — 410012882996301
    Web Money — R955262494655

  • Оцените статью