Универсальный поиск значений по метаданным

21.06.10

Разработка - Механизмы платформы 1С

Из-за разбиения  команд на выполнение НаКлиенте и НаСервере часто возникает необходимость поиска значения в справочнике/регистре или документе, а писать запрос для каждого случая не всегда удобно и приводит к избыточности кода.

//Параметры :

//ТаблицаВыборки (тип Строка) - имя таблицы на языке запросов в которой будут искаться данные

//РеквизитПоиска (тип Строка) - имя реквизита помещаемого в условие

// ЗначенияРеквизитПоиска (тип соответствует типу РеквизитаПоиска) - значение для условия

// ДопРеквизит - дополнительное условие

// ЗначениеДопРеквизита -значение доп условия

// РеквизитРезультата - указывать если необходимо получить поле с именем отличное от Ссылка



&НаСервере
Функция ПоискЗначения(ТаблицаВыборки,РеквизитПоиска,ЗначенияРеквизитПоиска,ДопРеквизит = Неопределено,ЗначениеДопРеквизита = Неопределено,РеквизитРезультата = Неопределено ) Экспорт
Запрос = Новый Запрос;


Если
РеквизитРезультата = Неопределено Тогда
ТекстЗапроса =
"ВЫБРАТЬ
| Таблица.Ссылка как Ссылка
|ИЗ
| "
+ТаблицаВыборки +" КАК Таблица
|ГДЕ
| Таблица."
+РеквизитПоиска+" = &ЗначенияДляПоиска";
Колонка = "Ссылка";
Иначе
ТекстЗапроса =
"ВЫБРАТЬ
| Таблица."
+РеквизитРезультата+" как "+РеквизитРезультата+"
|ИЗ
| "
+ТаблицаВыборки +" КАК Таблица
|ГДЕ
| Таблица."
+РеквизитПоиска+" = &ЗначенияДляПоиска";
Колонка = РеквизитПоиска;
КонецЕсли;


Если (
ДопРеквизит <> Неопределено) и (ЗначениеДопРеквизита <> Неопределено) Тогда
ТекстЗапроса = ТекстЗапроса +" И
|Таблица."
+ДопРеквизит+" = &ЗначениеДопРеквизита";


Запрос.УстановитьПараметр("ЗначениеДопРеквизита",ЗначениеДопРеквизита);
КонецЕсли;

Запрос.УстановитьПараметр("ЗначенияДляПоиска", ЗначенияДляПоиска);
Запрос.Текст = ТекстЗапроса;
Результат = Запрос.Выполнить();

ВыборкаДетальныеЗаписи = Результат.Выбрать();
Если
ВыборкаДетальныеЗаписи.Количество() = 1 Тогда
Если
ВыборкаДетальныеЗаписи.Следующий() Тогда
Возврат
ВыборкаДетальныеЗаписи[0]
КонецЕсли;
ИначеЕсли
ВыборкаДетальныеЗаписи.Количество() > 1 Тогда
Возврат
Результат.Выгрузить(ОбходРезультатаЗапроса.Прямой).ВыгрузитьКолонку(Колонка);

Иначе
Возврат Неопределено

КонецЕсли;

КонецФункции

 

Разместил в общем модуле, применяю для поиска значений в регистрах/справочниках/документах.

 

См. также

Поинтегрируем: сервисы интеграции – новый стандарт или просто коннектор?

Обмен между базами 1C Администрирование СУБД Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

В платформе 8.3.17 появился замечательный механизм «Сервисы интеграции». Многие считают, что это просто коннектор 1С:Шины. Так ли это?

11.03.2024    4538    dsdred    53    

72

Как готовить и есть массивы

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

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

24.01.2024    5295    YA_418728146    25    

63

Планы обмена VS История данных

Обмен между базами 1C Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Вы все еще регистрируете изменения только на Планах обмена и Регистрах сведений?

11.12.2023    6410    dsdred    36    

112

1С-ная магия

Механизмы платформы 1С Бесплатно (free)

Язык программирования 1С содержит много нюансов и особенностей, которые могут приводить к неожиданным для разработчика результатам. Сталкиваясь с ними, программист начинает лучше понимать логику платформы, а значит, быстрее выявлять ошибки и видеть потенциальные узкие места своего кода там, где позже можно было бы ещё долго медитировать с отладчиком в поисках источника проблемы. Мы рассмотрим разные примеры поведения кода 1С. Разберём результаты выполнения и ответим на вопросы «Почему?», «Как же так?» и «Зачем нам это знать?». 

06.10.2023    18475    SeiOkami    46    

118

Дефрагментация и реиндексация после перехода на платформу 8.3.22

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

Начиная с версии платформы 8.3.22 1С снимает стандартные блокировки БД на уровне страниц. Делаем рабочий скрипт, как раньше.

14.09.2023    12088    human_new    27    

74

Валидация JSON через XDTO (включая массивы)

WEB-интеграция Универсальные функции Механизмы платформы 1С Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

При работе с интеграциями рано или поздно придется столкнуться с получением JSON файлов. И, конечно же, жизнь заставит проверять файлы перед тем, как записывать данные в БД.

28.08.2023    8824    YA_418728146    6    

141

Внешние компоненты Native API на языке Rust - Просто!

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

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

20.08.2023    6279    sebekerga    54    

94

Все скопируем и вставим! (Буфер обмена в 1С 8.3.24)

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

Рассмотрим новую возможность 8.3.24 и как её можно эффективно использовать

27.06.2023    15986    SeiOkami    31    

103
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. alexk-is 6533 18.06.10 15:02 Сейчас в теме
(0) Код модуля в статье можно и получше раскрасить
Evg-Lylyk; +1 Ответить
2. php5 25 18.06.10 15:23 Сейчас в теме
А чем не нравится функция ПредопределенноеЗначение() ?
Reaper_1C; +1 Ответить
3. Поручик 4670 19.06.10 11:16 Сейчас в теме
В русском языке нет слова Реквезит.
4. xronos 116 21.06.10 13:37 Сейчас в теме
(3) ПредопределенноеЗначение() можно использовать если есть предопределеные значения. Для Перечислений/Констант лучше использовать конечно ПредопределенноеЗначение.
5. alexandr_astafiev 67 31.07.10 14:07 Сейчас в теме
косячок вроде мелкий , в запросе используется переменная - ЗначенияДляПоиска а в параметрах функции это называется - ЗначенияРеквизитПоиска или я ошибся?
6. Djonny 11.11.11 15:22 Сейчас в теме
Оставьте свое сообщение