Регистр сведений для хранения дополнительных данных

20.03.14

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

Бывает необходимость для хранения доп данных в зависимости от места расположения базы и пользователя, для этого был создан дополнительный Регистр Сведений

Измерения

  Пользователь     (СправочникСсылка.Пользователи)

  Контекст             (Строка 100)

  Идентификатор (Строка 100)

  СтрокаСоединенияСИБ (Строка 100)

Ресурсы

  Значение            (ЛюбаяСсылка, Булево, Строка, Дата, Число)

 

 

В модуле ФормыСписка на событие ПриНачалеРедактирования написано условие на добавление новой строки.

Процедура РегистрСведенийСписокПриНачалеРедактирования(Элемент, НоваяСтрока, Копирование)
    Если НоваяСтрока Тогда
        ТекСтрока = ЭлементыФормы.РегистрСведенийСписок.ТекущиеДанные;
        ТекСтрока.СтрокаСоединенияСИБ = СтрокаСоединенияИнформационнойБазы();
    КонецЕсли;
КонецПроцедуры

В модуль объекта добавлена функция:

Функция ПолучитьЗначение(Контекст,Идентификатор) Экспорт
    
    Запрос = Новый Запрос;
    Запрос.Текст =
    "ВЫБРАТЬ
    |    Нов_Константы.Значение
    |ИЗ
    |    РегистрСведений.Нов_Константы КАК Нов_Константы
    |ГДЕ
    |    Нов_Константы.Пользователь В (&Пользователь, ЗНАЧЕНИЕ(Справочник.Пользователи.ПустаяСсылка))
    |    И Нов_Константы.Контекст = &Контекст
    |    И Нов_Константы.Идентификатор = &Идентификатор
    |    И Нов_Константы.СтрокаСоединенияСИБ В (&СтрокаСоединенияСИБ, """")
    |
    |УПОРЯДОЧИТЬ ПО
    |    Нов_Константы.СтрокаСоединенияСИБ УБЫВ,
    |    Нов_Константы.Пользователь УБЫВ";
    
    Запрос.УстановитьПараметр("Пользователь",ПараметрыСеанса.ТекущийПользователь);
    Запрос.УстановитьПараметр("Контекст",Контекст);
    Запрос.УстановитьПараметр("Идентификатор",Идентификатор);
    Запрос.УстановитьПараметр("СтрокаСоединенияСИБ",СтрокаСоединенияИнформационнойБазы());
    Выборка = Запрос.Выполнить().Выбрать();
    
    Если Выборка.Следующий() Тогда
        Значение = Выборка.Значение;
    Иначе
        Выборка = Неопределено;
    КонецЕсли;
    
    Возврат Значение;    
    
КонецФункции

 

Пример использования данного регистра:

СоздатьПисьмо(РегистрыСведений.Нов_Константы.ПолучитьЗначение("Почта","НовыеКонтрагенты"),МассивСтрок);

P.S. Идея не моя, но очень хорошая в плане использования регл. заданий, внешних обработок и т.п.

       В дальнейшем думаю выложить пару вещей с использованием данного регистра.

См. также

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

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

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

11.03.2024    4431    dsdred    53    

70

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

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

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

24.01.2024    5271    YA_418728146    25    

62

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

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

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

11.12.2023    6389    dsdred    36    

111

1С-ная магия

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

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

06.10.2023    18463    SeiOkami    46    

118

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

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

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

14.09.2023    12073    human_new    27    

74

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

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

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

28.08.2023    8799    YA_418728146    6    

141

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

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

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

20.08.2023    6271    sebekerga    54    

94

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

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

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

27.06.2023    15959    SeiOkami    31    

103
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. GROOVY 2505 20.03.14 00:03 Сейчас в теме
Поправьте "индификаторы" и "регламентированные", а то очень глаза режет.

О чем статья не понял.
2. petname 46 20.03.14 11:08 Сейчас в теме
(1) GROOVY, спасибо, если не трудно посмотрите еще разок после редактирования. Коряво конечно, но мысль заключается в том чтобы хранить данные которые будут завязаны не только на определенные идентификатор, но и на пользователя и место соединения с базой.

PS русский не был моим любимым предметом в школе. (((
3. help1Ckr 26.03.14 12:30 Сейчас в теме
(2) petname, поддержу Павла - непонятна суть регистра. Что именно собираетесь хранить в регистре сведений?
4. petname 46 26.03.14 15:03 Сейчас в теме
(3) help1Ckr, в данный момент там хранятся ссылки на базы пользователи и пароли для ком соединения, почтовые адреса для рассылки специальных писем из внешних обработок (из клиент банка изменения посылаю ответственным лицам например)
5. CratosX 112 26.03.14 21:43 Сейчас в теме
А где в новом дизайне сайта можно ставить "минус"?
6. zhuravlev_as 392 03.04.14 11:06 Сейчас в теме
Это у Вас пример для типовой конфигурации какой-то или самописной? Если для типовой, то не помогает механизм дополнительных свойств и категорий(по другому доп. реквизитов), для справочников и документов? Меня этот механизм часто спасал, чтоб можно было хранить доп. данные без доработки конфы и работат/обрабатывать эти дополнительные данные.
7. petname 46 03.04.14 11:26 Сейчас в теме
(6) apostal86, Забыл указать что права на его просмотр и добавления ограничены. это помогает при обновлении. конфига ЗУП правда переписанная в хлам.
8. mikhailovaew 127 10.04.14 17:48 Сейчас в теме
Не вполне понятно назначение измерения СтрокаСоединенияСИБ. При работе с одной и той же базой (куда интегрирована Ваша подсистема) значение не будет меняться. Для каких целей понадобилось это измерение?
9. petname 46 10.04.14 19:53 Сейчас в теме
(8) mikhailovaew, работаешь с копией а забыл например отключить регламентные задания по выгрузке в другие базы
Оставьте свое сообщение