1
0
mirror of https://github.com/zerobig/fluent-request-schema-1c.git synced 2025-08-09 21:27:11 +02:00
Files
fluent-request-schema-1c/README.md

142 lines
10 KiB
Markdown
Raw Permalink Normal View History

2024-10-17 12:15:43 +03:00
# 1С Предприятие. Fluent запросы
2024-10-17 12:02:26 +03:00
2024-10-18 10:15:22 +03:00
[![OpenYellow](https://img.shields.io/endpoint?url=https://openyellow.org/data/badges/6/874099701.json)](https://openyellow.org/grid?data=top&repo=874099701)
2024-10-17 12:02:26 +03:00
## Мотивация
Смотрел я на запросы в 1С, потом смотрел на то как народ создаёт библиотеки с API в "текучем" стиле. И решил это совместить. Ведь есть же такой замечательный продукт от Microsoft - [Linq](https://learn.microsoft.com/ru-ru/dotnet/csharp/linq/standard-query-operators/)! Сначала подумал что буду первопроходцем. Но оказывается всё уже придумано до нас: [Раз](https://github.com/KalyakinAG/query-model), [Два](https://infostart.ru/1c/articles/1991009/). Может быть ещё что есть, а я не нашел.
2024-10-22 13:44:22 +03:00
## Отказ от повторения функционала
Данная библиотека не ставит перед собой цель полностью повторить функционал механизма запросов в 1С Предприятии. Я, как разработчик, даже считаю подобную цель вредной и едва ли достижимой. Ни одна библиотека никогда не сможет повторить полный синтаксис языка запросов так чтобы это было удобно для использования. В противном случае это будет уже не библиотека, а новый язык запросов.
2024-10-17 12:02:26 +03:00
## Описание
Библиотека позволяет писать запросы 1С Предприятия в функциональном стиле. Например, вот такой код:
```bsl
2024-10-22 16:02:18 +03:00
ТаблицаЗначений = СхЗапрос.НовыйЗапрос("Справочник.Номенклатура").ВТаблицуЗначений();
2024-10-17 12:02:26 +03:00
```
будет аналогичен:
```bsl
Запрос = Новый Запрос;
Запрос.Текст = "ВЫБРАТЬ
| Номенклатура.Ссылка КАК Ссылка
|ИЗ
| Справочник.Номенклатура КАК Номенклатура";
ТаблицаЗначений = Запрос.Выполнить().Выгрузить();
```
### Преимущества такого подхода:
* уменьшение количества кода при той же читабельности / наглядности;
* избавление от уродских конструкций типа:
```bls
Запрос.ТекстЗапроса = СтрЗаменить(Запрос.ТекстЗапроса, "&Условие", "Номенклатура.ЭтоГруппа = ЛОЖЬ");
```
### У существующих решений есть ряд недостатков:
* излишне многословны;
* не готовы к применению в рабочих конфигурациях;
* не соответствуют стандартам разработки;
2024-10-17 12:07:44 +03:00
* статья на инфостарте так и осталась лишь статьёй, не вылившись в какую-то готовую разработку;
2024-10-17 12:02:26 +03:00
### У моего решения тоже есть недостатки:
* отсутствует автодополнение кода;
2024-10-17 12:25:34 +03:00
* не полная функциональность (разработка пока в статусе 'beta')
2024-10-17 12:02:26 +03:00
### Личные переживания и сомнения в процессе разработки
Сначала я был полон энтузиазма. Потом, по мере написания кода, начали появляться сомнения. Нужно ли это? Верной ли дорогой иду? Но когда я увидел как вот это:
```bsl
Функция ТаблицаАдресныхСокращений(НаименованияАдресныхОбъектов)
Запрос = Новый Запрос;
Запрос.Текст =
"ВЫБРАТЬ
| УровниСокращенийАдресныхСведений.Значение КАК Наименование,
| УровниСокращенийАдресныхСведений.Сокращение КАК Сокращение
|ИЗ
| РегистрСведений.УровниСокращенийАдресныхСведений КАК УровниСокращенийАдресныхСведений
|ГДЕ
| &Условие
|
|СГРУППИРОВАТЬ ПО
| УровниСокращенийАдресныхСведений.Значение,
| УровниСокращенийАдресныхСведений.Сокращение
|
|УПОРЯДОЧИТЬ ПО
| Наименование";
Если ТипЗнч(НаименованияАдресныхОбъектов) = Тип("Массив") И НаименованияАдресныхОбъектов.Количество() > 0 Тогда
Условие = "ИСТИНА";
Иначе
Условие = "УровниСокращенийАдресныхСведений.Значение В(&АдресныеСокращения)";
Запрос.УстановитьПараметр("АдресныеСокращения", НаименованияАдресныхОбъектов);
КонецЕсли;
Запрос.Текст = СтрЗаменить(Запрос.Текст, "&Условие", Условие);
Возврат Запрос.Выполнить().Выгрузить();
КонецФункции
```
превратилось вот в это:
```bsl
Функция ТаблицаАдресныхСокращений(НаименованияАдресныхОбъектов)
2024-10-22 16:02:18 +03:00
Запрос = СхЗапрос.НовыйЗапрос("РегистрСведений.УровниСокращенийАдресныхСведений")
2024-10-17 12:02:26 +03:00
.Выбрать("Значение КАК Наименование, Сокращение")
.Сгруппировать("Значение, Сокращение")
.Упорядочить("Наименование");
Если ТипЗнч(НаименованияАдресныхОбъектов) = Тип("Массив") И НаименованияАдресныхОбъектов.Количество() > 0 Тогда
Запрос = Запрос
2024-10-22 16:02:18 +03:00
.Где(СхЗапрос.Предикат()
2024-10-17 12:02:26 +03:00
.Реквизит("Значение").В(НаименованияАдресныхОбъектов));
КонецЕсли;
Возврат Запрос.ВТаблицуЗначений();
КонецФункции
```
все сомнения отпали! 16 строк вместо 30-ти при сохранении общей читабельности. И качество кода улучшилось за счет отказа от конструкции `СтрЗаменить()`.
По-моему это заявка на успех!
## Документация
2024-10-18 10:50:06 +03:00
Документация находится по адресу [https://zerobig.github.io/fluent-request-schema-1c/](https://zerobig.github.io/fluent-request-schema-1c/). Наполнение продолжается.
2024-10-17 12:02:26 +03:00
## Как запустить
2024-10-17 12:07:44 +03:00
* Вариант 1: скачать файл с расширением cf из раздела [Releases](https://github.com/zerobig/fluent-request-schema-1c/releases) и объединить со своей конфигурацией;
* Вариант 2: скачать файл с расширением cfe из раздела [Releases](https://github.com/zerobig/fluent-request-schema-1c/releases) и установить это расширение в свою базу данных;
2024-10-17 12:02:26 +03:00
* Вариант 3: скачать исходники из репозитория, собрать при помощи команды `npm run build` (потребуется установленная NodeJS) и использовать результаты сборки по своему усмотрению;
2024-10-17 12:44:45 +03:00
## Тестирование
Тесты писались при помощи расширения для запуска тестов [YAxUnit](https://github.com/bia-technologies/yaxunit). И выполнялись на типовой конфигурации Управление торговлей ред.11.5 (11.5.18.41). Это надо учитывать при самостоятельном запуске тестов.
2024-10-21 14:27:19 +03:00
**Внимание!** YAxUnit для регулярных выражений использует внешнюю компоненту, так что требуется снять флаг безопасного режима. Иначе внешняя компонента не будет запущена.
2024-10-17 12:39:31 +03:00
## Идеи по дальнейшему развитию (roadmap)
2024-10-17 12:02:26 +03:00
2024-10-18 10:41:15 +03:00
- [x] создание документации;
2024-10-17 12:02:26 +03:00
- [ ] расширение API методов:
2024-10-20 15:45:56 +03:00
- [x] вложенные запросы;
2024-10-17 12:02:26 +03:00
- [ ] пакетные запросы;
2024-10-17 12:39:31 +03:00
- [ ] временные таблицы;
2024-11-15 10:16:02 +03:00
- [x] виртуальные таблицы;
2024-10-17 12:39:31 +03:00
- [ ] индексирование;
2024-10-17 12:02:26 +03:00
- [ ] увеличение полноты покрытия тестами;
2024-10-18 16:38:46 +03:00
- [x] обработка-конструктор, которая преобразует обычный запрос 1С в "текучие" выражения и обратно;
2024-10-17 12:39:31 +03:00
- [ ] вариант библиотеки для [OneScript](https://github.com/EvilBeaver/OneScript). Пока не понятно, возможно ли и нужно ли? Идея на этапе исследования;
- [ ] CI/CD
2024-10-17 12:02:26 +03:00
## Благодарности
* [YAxUnit](https://github.com/bia-technologies/yaxunit) - ребята, вы лучшие!
* [1CFilesConverter](https://github.com/arkuznetsov/1CFilesConverter) - давно пользуюсь этими скриптами. Очень помогают.