Фирма «1С» анонсировала изменения в языке запросов и выражениях СКД для 8.3.22

Фирма «1С» анонсировала изменения в языке запросов и выражениях СКД для 8.3.22
19.11.2021
77890

Фирма «1С» планирует добавить новую функцию для получения уникального идентификатора объекта из ссылки в запросе. Функциональность будет полезна при интеграции приложений 1С с внешними системами.

Что планируют изменить в языке запросов

Официальный технологический блог «Заметки из Зазеркалья» анонсировал изменения в языке запросов и выражениях СКД. Начиная с версии 8.3.22 в технологической платформе добавится функция УникальныйИдентификатор(Ссылка), где параметр Ссылка – выражение, результатом которого является ссылка (кроме ссылок на таблицы внешних источников данных). Функция возвращает уникальный идентификатор переданной ссылки или NULL, если передано значение NULL.

Данное нововведение сделано по многочисленным просьбам сообщества разработчиков 1С, и должно упростить задачи интеграции систем на платформе 1С:Предприятие с внешними системами.

Как будет работать новая функция

В качестве примера работы новой функциональности приводится интеграция с внешней системой на уровне данных, когда таблица внешней системы ссылается на справочник «Товары» в исходной информационной базе, а структура таблицы внешней системы имеет такой вид:

 

Идентификатор

Ключ (число)

Наименование

Название товара на английском языке (строка)

УникальныйИдентификатор

Ссылка на элемент справочника Товары (уникальный идентификатор)

 

Для решения такой задачи нужно на стороне 1С вывести содержимое справочника «Товары», и для каждого товара показать его название на английском языке.

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

  1. Добавить в таблицу значений колонку, которую надо заполнить ссылкой на элементы справочника «Товары», обойдя все записи таблицы значений в цикле.
  2. Полученную таблицу значений с помощью запроса объединить со справочником «Товары».

С использованием новой функции, начиная с 1С 8.3.22, сделать это можно будет значительно проще:

 

Пример кода, иллюстрирующий работу новой функции.
Источник: wonderland.v8.1c.ru

 

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

Если вам удобнее смотреть новости в телеграме, то вот наша группа – ИНФОСТАРТ.

Автор:
Обозреватель

См. также

1С:Предприятие.Элемент 8 содержит новую прикладную функциональность и развитие средств разработки. Рассказываем о наиболее важных нововведениях.

вчера в 13:16    311    ЕленаЧерепнева    0       

3

Фирма «1С» сообщила о выпуске тестовой версии 1С:EDT 2025.1. В состав релиза включили автоматическую проверку Java, обновленный редактор форм, улучшения для конструктора запросов и другие возможности для удобства разработчиков.

вчера в 11:04    241    ЕленаЧерепнева    0       

2

С 1 января 2026 года ФНС станет оценивать финансово-хозяйственную деятельность юрлиц и ИП. Соответствующие изменения вносят в законодательство. Бизнес сможет получить выписки по результатам оценки деятельности и оспорить итоги.

01.08.2025    445    user2146402    0       

1

Фирма «1С» анонсировала новую функциональность для работы с заархивированными файлами в платформе 1С 8.5.3. Прежде всего, это будет полезно для работы с электронными документами, и расширит возможные сценарии работы для решений 1С.

31.07.2025    593    ЕленаЧерепнева    0       

3

Решение уже доступно зарегистрированным пользователям Документооборот ПРОФ и партнерам в сервисе 1С:Обновление программ. Рассказываем о главных возможностях облегченной версии Документооборота 3.0 и условиях сопровождения тестового релиза.

31.07.2025    504    ЕленаЧерепнева    0       

3

В состав релиза включили новые возможности для работы с документом «Счет», поддержку изменений от ФНС, а также несколько новых возможностей для маркетплейсов и учета малоценки.

29.07.2025    716    ЕленаЧерепнева    0       

2

Фирма «1С» напомнила о продолжении закрытого тестирования плагина 1С:Напарник для разработки в 1С:EDT и опубликовала в официальном технологическом блоге актуальный обзор продукта. Рассказываем, что сейчас известно о возможностях ИИ-помощника для 1С.

28.07.2025    668    ЕленаЧерепнева    1       

9

Готовый продукт для автоматической интеграции внешних компонент для Firefox, Chrome, MSIE, Chromium-based уже доступен зарегистрированным пользователям 1С с активным ИТС. Рассказываем о возможностях инструмента и условиях использования.

23.07.2025    877    ЕленаЧерепнева    0       

3

Комментарии

Инфостарт бот
1. ImHunter 19.11.21 15:57 Сейчас в теме
Еще бы генерилось новое значение, например, если в ф-ю передать Неопределено.
2. insurgut 20.11.21 07:26 Сейчас в теме
Ещё бы на уровне запросов можно было определять битая ссылка или нет, отбирать запросом записи с битыми ссылками.
3. karpik666 20.11.21 15:20 Сейчас в теме
(2) ну по идее это итак есть, надо сравнить с пустой ссылкой, и добавить проверку на Значение.Ссылка is NULL , тогда вернутся все битые ссылки.
4. insurgut 20.11.21 17:19 Сейчас в теме
(3) не работает это. Как минимум для полей с составным типом данных.
5. karpik666 20.11.21 17:22 Сейчас в теме
(4) Для составного типа надо добавить проверок на все типы, что туда входят, плюс на неопределено, но принцип тот же.
6. insurgut 20.11.21 17:25 Сейчас в теме
(5) так?
ВЫБРАТЬ
	ПлатежныйКалендарь.Период КАК Период,
	ПлатежныйКалендарь.Регистратор КАК Регистратор,
	ПлатежныйКалендарь.СчетНаОплату КАК СчетНаОплату
ИЗ
	РегистрНакопления.ПлатежныйКалендарь КАК ПлатежныйКалендарь
ГДЕ
	ВЫРАЗИТЬ(ПлатежныйКалендарь.СчетНаОплату КАК Документ.ЗаказПокупателя) ЕСТЬ NULL
	И НЕ ВЫРАЗИТЬ(ПлатежныйКалендарь.СчетНаОплату КАК Документ.ЗаказПокупателя) = НЕОПРЕДЕЛЕНО
Показать
7. karpik666 20.11.21 17:29 Сейчас в теме
(6) вот так
ВЫБРАТЬ
    ПлатежныйКалендарь.Период КАК Период,
    ПлатежныйКалендарь.Регистратор КАК Регистратор,
    ПлатежныйКалендарь.СчетНаОплату КАК СчетНаОплату
ИЗ
    РегистрНакопления.ПлатежныйКалендарь КАК ПлатежныйКалендарь
ГДЕ
    ВЫРАЗИТЬ(ПлатежныйКалендарь.СчетНаОплату КАК Документ.ЗаказПокупателя).Ссылка ЕСТЬ NULL
    И ПлатежныйКалендарь.СчетНаОплату Ссылка Документ.ЗаказПокупателя
    И НЕ ПлатежныйКалендарь.СчетНаОплату = Значение(Документ.ЗаказПокупателя.ПустаяСсылка)
Показать
m_aster; insurgut; +2 Ответить
8. insurgut 20.11.21 17:33 Сейчас в теме
(7) всё понял где собака зарыта, не само Значение проверять на ЕСТЬ NULL, а Значение.Ссылка. Спасибо!

P.S. Но конечно что-то вроде "ГДЕ ЭтоБитаяСсылка(ЗаписьРегистра.Регистратор) = ИСТИНА" вне зависимости от того, составной тип у поля или нет - очень упростило бы жизнь.

Оставьте свое сообщение