Новые возможности языка запросов в платформе 8.3.20

27.09.22

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

С платформы 8.3.20 анонсировали ряд изменений в языке запросов, с которыми интересно было повозиться на практике, что и было проделано. Результатом этих изысканий решил поделиться с вами.

Анонсированные возможности (кратко)

Анонс новых возможностей можно посмотреть по ссылке, если кратко, можно выделить три больших блока добавлений:

  1. Добавлены новые арифметические операции: округление, логарифмы, квадратные корни и т.д.
  2. Добавлена возможность преобразования в строку и расширение работы со строками: обрезка строк, удаление пробелов и т.д.
  3. Добавлена возможность получать размер хранимых данных через метод РазмерХранимыхДанных.

Вот со всем этим и хотелось познакомится поподробнее. Все эксперименты проводились на платформе 8.3.20.1613.

 

Арифметические возможности

В платформе анонсировали следующие возможности:

  • Тригонометрические функции Sin, Cos, Tan, ASin, ACos, ATan (все вычисления производятся в радианах)
  • Exp - вычисляет результат возведения основания натурального логарифма (числа e) в степень
  • Log - вычисляет натуральный логарифм числа.
  • Log10 - вычисляет десятичный логарифм числа.
  • Pow - вычисляет возведение в степень.
  • Sqrt – вычисляет квадратный корень.
  • Окр(Round) - округляет исходное число до нужной разрядности
  • Цел(Int) - вычисляет целую часть переданного числа, полностью отсекая дробную часть.
 
 Код проверки

Выявлены следующие особенности:

  1. Данные операторы работают строго с числами. При попадании туда любого другого значения, включая  NULL или Неопределено - платформа выдаст ошибку.

 

 

  1. Данные операторы не могут работать с полями составного типа без явного приведения к числу (оператор ВЫРАЗИТЬ ).

 

 

  1. В арифметических операциях можно влететь в невозможность вычислить выражение из-за слишком большого числа. Ошибка ниже возникла при попытке посчитать exp от 500. Попытки вставить "ВЫРАЗИТЬ" и т.д. ни к чему не привели.

 

В целом с арифметическим операциями всё - переходим к работе со строками.

 

Работа со строками.

В платформе анонсировали следующие возможности:

  • Строка(String) – преобразует значение примитивного типа в строку с учетом национальных установок.
  • ДлинаСтроки(StringLength) – вычисляет длину строки.
  • СокрЛ(TrimL) – отбрасывает незначащие пробелы слева.
  • СокрП(TrimR) – отбрасывает незначащие пробелы справа.
  • СокрЛП(TrimAll) – отбрасывает незначащие пробелы слева и справа.
  • Лев(Left) – получает первые слева символы строки.
  • Прав(Right) – получает первые справа символы строки.
  • СтрНайти(StrFind) – находит первую позицию подстроки в строке (без учета регистра).
  • ВРег(Upper) – преобразует все символы строки в верхний регистр.
  • НРег(Lower) – преобразует все символы строки в нижний регистр.
  • СтрЗаменить(StrReplace) – заменяет все вхождения подстроки на другую подстроку (без учета регистра).

В данном случае будет 2 эксперимента, т.к. функцию Строка хотелось погонять "в хвост и в гриву".

Работа функции Строка

 
 Код проверки

Выявлены следующие особенности:

  1. Умеет преобразовывать любые примитивные типы, включая NULL или Неопределено (см. пример).
  2. Не умеет преобразовывать ссылки на объекты, в том числе предопределённые элементы.

 

 

  1. Если использовать функцию Строка на строку неограниченной длинны - запрос спокойно отработает. Ради интереса вставил в реквизит текст первого тома "Война и мир" - запрос выполнился без вопросов и в результате получил весь текст из реквизита.

 

Прочие функции работы со строками

 
 Код проверки

Выявлены следующие особенности:

  1. Остальные функции отказываются работать с любыми типами, кроме Строка
  2. Все эти функции умеют работать со строками неограниченной длинны.
  3. Конструктор ловить лишь часть ошибок по типизации, а часть вылезет только на клиенте.
 
Интересная особенность (баг или фича)

 

Функция РазмерХранимыхДанных

В платформе анонсировали следующие возможности:

> РазмерХранимыхДанных(StoredDataSize) – возвращает размер данных в байтах, которые занимают данные параметра.

Данная функция будет применима не только к хранилищу значений (как почему-то подумалось мне изначально), а к любому существующему в базе реквизиту (ну, почти к любому).

 
 Код проверки

Выявлены следующие особенности:

  1. Любая ошибка с размером хранимых данных приводит к вылету платформы.

 

 

  1. Надо чётко понимать, что является реквизитом ИБ, а что нет, т.к. подсказка в конструкторе работает далеко не всегда. (Н-р: попытка обращения к полям Представление , Предопределённый - приведут к ошибке (см. пример проверки)).   
  2. Получить общий размер табличной части таким образом не получится, что собственно следует из определения, но проверить нужно было.

 

 

Заключение.

Доклад окончен. Целью статьи было попробовать для себя и показать другим как работают новые возможности языка запросов, какие есть при этом ограничения и нюансы, о которых можно изначально не подумать. Спасибо за внимание.

Если вдруг кому нужна обработка, в которой я накидывал данные примеры кода - см. мой github

Запросы 8.3.20

См. также

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

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

12000 руб.

02.09.2020    169258    937    403    

905

Запросы Программист Бесплатно (free)

Увидел cheatsheet по SQL и захотелось нарисовать подобное, но про запросы.

18.10.2024    11391    sergey279    18    

65

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

Столкнулся с интересной ситуацией, которую хотел бы разобрать, ввиду её неочевидности. Речь пойдёт про использование функции запроса АВТОНОМЕРЗАПИСИ() и проблемы, которые могут возникнуть.

11.10.2024    6338    XilDen    36    

83

Запросы Программист Запросы Бесплатно (free)

Отлаживая взаимодействие с базой данных, мы регулярно сталкиваемся с зависающими или подозрительно долго выполняющимися обращениями, негативно влияющими на производительность. О том, как в PostgreSQL выявить подозрительные запросы, основываясь на доступной о них информации, расскажем в статье.

16.08.2024    9066    user1840182    5    

28

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

Рассмотрим быстрый алгоритм поиска дублей с использованием hash функции по набору полей шапки и табличных частей.

08.07.2024    2727    ivanov660    9    

22

Запросы СКД Программист Стажер Система компоновки данных Россия Бесплатно (free)

Часто при разработке отчетов в СКД возникает ситуация, когда не совсем понятно, почему отчет выводит не те данные, которые нужны, либо не выводит вовсе. Возникает потребность увидеть конечный запрос, который формирует СКД. Как это сделать, рассмотрим в этой статье.

15.05.2024    10219    implecs_team    6    

48

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

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

11.04.2024    3623    andrey_sag    10    

38
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. DrAku1a 1748 28.09.22 09:07 Сейчас в теме
Полезные и нужные функции. Время от времени такое надо. Большая часть их поддерживается SQL нативно (т.е. будет преобразовываться 1 в 1).
2. ixijixi 1975 28.09.22 09:13 Сейчас в теме
Оффтоп: как выделить текст таким образом?
Прикрепленные файлы:
3. zeltyr 692 28.09.22 09:55 Сейчас в теме
(2) примерно так, только убрать пробелы в тегах
< code >РазмерХранимыхДанных< /code >
4. ixijixi 1975 28.09.22 10:00 Сейчас в теме
(3) Чет не работает =\
Прикрепленные файлы:
5. zeltyr 692 28.09.22 10:06 Сейчас в теме
(4) ну, в редакторе статьи это надо вставлять в режиме редактирования исходного текста.
Прикрепленные файлы:
6. ixijixi 1975 28.09.22 10:10 Сейчас в теме
(5) Спасибо, получилось!
Прикрепленные файлы:
Arkadiy_B; +1 Ответить
7. kser87 2450 28.09.22 16:07 Сейчас в теме
8. Pira 149 28.09.22 17:52 Сейчас в теме
(7) Почему не прошло? Прошло уже!
mikukrnet; корум; EvilMilko; +3 Ответить
9. Dzenn 899 29.09.22 11:26 Сейчас в теме
(7) критиковать легко, делать сложно ) думаю, у них было полно более приоритетных задач, а ресурсы конечно ограничены
pbahushevich; Brawler; ledywinter; +3 Ответить
10. Jimbo 11 29.09.22 13:36 Сейчас в теме
Интересно и зачем вам ВЫБРАТЬ EXP(500)?
1c 8.3.21.1508 удалось только ВЫБРАТЬ EXP(66), хотя в MS SQL 2019 легко выдаст Select EXP(500). Видать не так уж и проста трансляция языка запросов 1с в язык SQL.
11. VVi3ard 52 29.09.22 16:27 Сейчас в теме
(10) Возможно потому что одна из других СУБД которые поддерживает платформа (включая файловую) не умеет EXP(500).

Как то постоянно все забывают что главный якорь платформы в плане работы с СУБД это файловый вариант, второй по влиянию это IBM DB2.
13. zeltyr 692 30.09.22 06:47 Сейчас в теме
(10)
Интересно и зачем вам ВЫБРАТЬ EXP(500)?

Исключительно в целях эксперимента "а сможет ли". Одной из задач, которые я себе ставил - добиться НЕ выполнения данных функций, чтобы найти их ограничения. Что я и постарался воплотить...
dock; pbahushevich; +2 Ответить
12. Darklight 33 29.09.22 16:54 Сейчас в теме
А что там с дополнительными параметрами некоторых функций - например можно вызвать Лев(ПолеСтрока, ПолеЧисло)?
И с вложением функций СокрЛП(СтрЗаменить(ПолеСтрока, Лев(ПолеСтрока,СтрНайти(ПолеСтрока,"-")-1)+, Прав(ПолеСтрока,СтрНайти(ПолеСтрока,"-"),ДлинаСтроки(ПолеСтрока)-Лев(ПолеСтрока,СтрНайти(ПолеСтрока,"-"))))
И как нынче всё это сочетается со старой функцией ПОДСТРОКА?
И индексация символов по-прежнему с 1?
А функции перевода строки в число, булево, в дату, в неопределено - так и не появилось?
И нет ли функции как ЕСТЬNULL и как оператора ЕСТЬ NULL - только в более широком смысле - как операция условия "Не заполнено" из СКД (т.е. проверяющая не только на NULL, но и на неопределено и пустые ссылки)?
mikukrnet; +1 Ответить
14. zeltyr 692 30.09.22 07:08 Сейчас в теме
(12) Ух как много вопросов и как мало у меня ответов... Но попробуем.

А что там с дополнительными параметрами некоторых функций - например можно вызвать Лев(ПолеСтрока, ПолеЧисло)?


Можно. Причём если число будет отрицательное, то выведет просто 0 символов.

И с вложением функций СокрЛП(СтрЗаменить(ПолеСтрока, Лев(ПолеСтрока,СтрНайти(ПолеСтрока,"-")-1)+, Прав(ПолеСтрока,СтрНайти(ПолеСтрока,"-"),ДлинаСтроки(ПолеСтрока)-Лев(ПолеСтрока,СтрНайти(ПолеСтрока,"-"))))


СОКРЛП(СТРЗАМЕНИТЬ(РаботаСоСтроками.СтрокаСПробеламиВНачалеИКонце, ЛЕВ(РаботаСоСтроками.СтрокаСПробеламиВНачалеИКонце, СТРНАЙТИ(РаботаСоСтроками.СтрокаСПробеламиВНачалеИКонце, ""5"") - 1), ""привет""))

вот такой пример точно отработал, так что думаю тут тоже всё хорошо.

И как нынче всё это сочетается со старой функцией ПОДСТРОКА?


1. Подстрока и СокрЛП / СОКРЛ / СОКРП - работают вместе вполне нормально.
ПОДСТРОКА(РаботаСоСтроками.СтрокаСПробеламиВНачалеИКонце, 3, 2) + СОКРЛП(РаботаСоСтроками.СтрокаСПробеламиВНачалеИКонце)


2. Подстрока и ЛЕВ / ПРАВ и т.д. не работают вместе. Стока ниже выдаёт ошибку (см. скрин к комментарию)
ПОДСТРОКА(РаботаСоСтроками.СтрокаСПробеламиВНачалеИКонце, 3, 2) + ЛЕВ(РаботаСоСтроками.СтрокаСПробеламиВНачалеИКонце, 4)



И индексация символов по-прежнему с 1?

Да.

А функции перевода строки в число, булево, в дату, в неопределено - так и не появилось?

Да, так и не появилось.

И нет ли функции как ЕСТЬNULL и как оператора ЕСТЬ NULL - только в более широком смысле - как операция условия "Не заполнено" из СКД (т.е. проверяющая не только на NULL, но и на неопределено и пустые ссылки)?

Из анонса не следовало, так что похоже нет. Но очень глубоко не копал.

P.S. Если кто захочет посмотреть на код, которым я это проверял - сделал доработку в обработке для экспериментов, ссылка на которую приложена к статье.
Прикрепленные файлы:
15. Darklight 33 30.09.22 13:38 Сейчас в теме
(14)Очень странно что с ПОДСТРОКА 1. работает, а 2. уже нет - но больше интересовало, конечно как-то так так
СокрП(ПОДСТРОКА(СокрЛП(ПолеСтрока), 1, СтрНайти(СокрЛП(ПолеСтрока),".")-1))+СокрЛ(ПОДСТРОКА(СокрЛП(ПолеСтрока), СтрНайти(СокрЛП(ПолеСтрока),".")+1, ДлинаСтроки(СокрЛП(ПолеСтрока))))
16. Abduvali 2 30.09.22 20:21 Сейчас в теме
Полезная статья, спасибо!
17. naf2000 03.10.22 19:10 Сейчас в теме
IQueryable но встроенный в платформу
18. CepeLLlka 76 15.06.23 21:05 Сейчас в теме
1С:Предприятие 8.3 (8.3.20.2184)

"ВЫБРАТЬ
ОКР(20212.77, 2) КАК Зарплата"


В результате получаю - 20 212,77

ЧЯДНТ???
19. CepeLLlka 76 15.06.23 22:08 Сейчас в теме
(18)Всё норм, я прост затупил дичайше :)
20. Bovori 2 25.07.23 09:15 Сейчас в теме
Любопытное поведение СТРНАЙТИ() совместно С ПОМЕСТИТЬ.
два варианта запроса:
1.
ВЫБРАТЬ
	"SL_Cloud_Support_Lead" КАК Наименование
ПОМЕСТИТЬ ИсходДанные

ОБЪЕДИНИТЬ

ВЫБРАТЬ
	"SL_Cloud_Support_Lead_FY23"
;

////////////////////////////////////////////////////////////­////////////////////
ВЫБРАТЬ
	ИсходДанные.Наименование КАК Наименование,
	ВЫБОР
		КОГДА НЕ СТРНАЙТИ(ИсходДанные.Наименование, "_FY23") = 0
			ТОГДА 
			СТРЗАМЕНИТЬ(ИсходДанные.Наименование, "_FY23", "")
		ИНАЧЕ ИсходДанные.Наименование
	КОНЕЦ 
	КАК НаименованиеФормат
ПОМЕСТИТЬ Результат
ИЗ
	ИсходДанные КАК ИсходДанные
Показать


2.
ВЫБРАТЬ
	"SL_Cloud_Support_Lead" КАК Наименование
ПОМЕСТИТЬ ИсходДанные

ОБЪЕДИНИТЬ

ВЫБРАТЬ
	"SL_Cloud_Support_Lead_FY23"
;

////////////////////////////////////////////////////////////­////////////////////
ВЫБРАТЬ
	ИсходДанные.Наименование КАК Наименование,
	СТРЗАМЕНИТЬ(ИсходДанные.Наименование, "_FY23", "") КАК НаименованиеФормат
ПОМЕСТИТЬ Результат
ИЗ
	ИсходДанные КАК ИсходДанные
Показать

выполнение второго запроса выдает ошибку(на скрине). Если во втором убрать
ПОМЕСТИТЬ Результат
то все нормально. С первым вариантом запроса проблем нет.
Прикрепленные файлы:
21. Anthon 231 14.12.23 10:05 Сейчас в теме
СтрЗаменить(СтрЗаменить(
не работает. То есть если надо заменить два значения, строка портится, так как заменяется текст в полученной строке, но в местоположении исходной. Возможно, будет работать нормально, если все подстроки второй замены будут находиться РАНЬШЕ ВСЕХ подстрок первой замены
Оставьте свое сообщение