Обычный и предопределенный элементы. Различие на стороне базы данных

На четвертом уроке нашего мы продолжим знакомиться с программой . Сегодня мы на практических примерах познакомимся с и ерархическими справочниками, а также научимся создавать предопределенные элементы .

Хронометраж 4 урока курса:

00:19 Изменения в справочнике Сотрудники после выполнения домашнего задания по 3 уроку курса
00:35 Редактирование порядка следования реквизитов в справочниках
02:54 Создание справочника Номенклатура
03:40 Создание и настройка иерархического справочника
05:10 Создание групп Услуги и Товары в справочнике Номенклатура
06:05 Заполнение справочника Номенклатура
07:14 3 способа переноса элемента справочника в другую группу
08:21 Создание справочника Склады
09:19 Создание предопределенных элементов справочника
11:25 Заполнение справочника Склады
12:20 Пройти тест по материалу 4 урока

Иерархический справочник – справочник с возможностью иерархического расположения его элементов. Например, в справочнике Номенклатура могут быть созданы группы: Товары, Услуги и т.д., в которых располагаются элементы, относящиеся к этим группам. Кроме того группы справочника могут включать в себя и другие группы, создавая тем самым многоуровневую иерархическую структуру.

Кроме этого, справочники поддерживают и другой вид иерархии, при котором элементы справочника будут относиться не к группам, а к другим элементам этого же справочника. Такой вид иерархии (иерархия элементов ) может использоваться, например, при создании справочника Подразделения, где одно подразделение (подразделение в данном случае элемент справочника, а не группа) может включать в себя несколько других подразделений. Такой вид иерархии применяется достаточно редко.

Формы справочника – визуальное представление справочника. В зависимости от того, какие именно действия мы хотим выполнить с нашим справочником, нам требуется отображать справочник в «различных видах». Так, на 4 уроке курса мы с вами редактировали порядок следования реквизитов в форме списка и в форме элемента справочника.

Система создает (генерирует) формы автоматически, но, при необходимости, разработчик можем «рисовать» формы самостоятельно.

Всего для справочников существует 5 форм (типов форм):

  • форма элемента – для создания или редактирования элемента справочника;
  • форма группы - для создания или редактирования группы справочника;
  • форма списка – для отображения списка элементов справочника;
  • форма выбора - используется, чтобы в поле некой формы выбрать один из элементов данного справочника. Например, чтобы в документе Поступление товара в поле склад выбрать конкретный склад из справочника Склады;
  • форма выбора групп – используется, чтобы в поле некой формы выбрать одну из групп данного справочника.

Предопределенные элементы справочника – элементы справочника, создаваемые разработчиком в режиме Конфигуратора, и к которым можно обращаться из встроенного языка 1с по Имени.

Между обычными и предопределенными элементами справочника существует принципиальная разница. Обычные элементы непостоянны в конфигурации. В процесс работы пользователя они могут создаваться, редактироваться и удаляться и, именно поэтому, на них не следует полагаться при выполнении каких-либо алгоритмов (код и наименование элемента может изменяться пользователем). Предопределенные элементы, напротив, постоянные. В процессе работы, даже если пользователь переименует такой элемент, к нему можно будет обращаться из встроенного языка 1с. Это достигается за счет того, что у предопределенного элемента есть реквизит Имя , который недоступен пользователю. У обычных элементов справочника такого реквизита нет.

Важно! Технически пользователь имет возможность удалить предопределенный элемент справочника, но, как правило, пользователям отключают права на удаление предопределенных элементов справочника.

Домашнее задание по 4 уроку курса

Домашнее задание по четвертому уроку курса будет вам доступно сразу после успешного решения теоретического теста.

Внимание! Перед вами ознакомительная версия урока, материалы которого могут быть неполными.

Войдите на сайт как ученик

Войдите как ученик, чтобы получить доступ к материалам школы

Язык запросов 1С 8.3 для начинающих программистов: функция ЗНАЧЕНИЕ

Функция ЗНАЧЕНИЕ предназначена для обращения в тексте запроса к значениям системных перечислений и предопределенным данным .

Что ещё за перечисления и предопределенные данные, спросите вы. Давайте обо всё по порядку.

Перечисления

Перечисления - это прикладной объект (вы помните, что ещё существуют Справочники и Документы ). Зачем он понадобился?

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

Неизменность - это их главный козырь. Это своеобразные константы базы данных.

И если программист в режиме конфигурирования создал перечисление с именем Пол и значениями Мужской и Женский , то при написании программы он может быть уверен, что в дальнейшем значения этого перечисления не изменятся. Поэтому он может смело обращаться к этим значениям из кода.

Представьте, что будет, если он попытается для этих целей использовать справочник?

Во-первых, какой-нибудь пользователь возьмёт да и добавит какой-нибудь "Марсианский пол".

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

А программа от этого сломается, потому что для её работы необходимо, чтобы было ровно два пола и именно с именами "Мужской" и "Женский".

Вот для таких случаев, как раз и существуют перечисления: чтобы один раз (ещё на этапе конфигурирования) жестко задать все возможные варианты значений и в дальнейшем использовать их в коде программ.

Давайте рассмотрим пример такого перечисления в нашей базе "Гастроном". Вы читаете ознакомительную версию урока, полноценные уроки находятся .

Вот оно наше перечисление с именем Пол . Какие значения оно может принимать?

Всего два значения. С именами "Мужской" и "Женский". То что нам надо.

Где мы в дальнейшем можем использовать это перечисление? Ну, конечно, в справочнике Клиенты . Обратите внимание, что в его списке появился новый реквизит с именем Пол и типом Перечисление.Пол :

Таким образом, при заполнении карточки клиента уже в режиме пользователя мы сможем в качестве пола клиента выбирать всего из двух значений Мужской и Женский:

Теперь давайте составим запрос, выбирающий клиентов и их пол из базы:

А теперь давайте изменим запрос, чтобы остались только мужчины. Если мы попробуем написать что-то типа:

то ничего не получим:

Потому что к значениям перечисления так обращаться нельзя. К ним нужно обращаться используя функцию ЗНАЧЕНИЕ :

Итак, одна из задач функции ЗНАЧЕНИЕ - использование в запросах значений перечислений.

Предопределенные данные

Я лучше покажу на примере, что такое предопределенные данные для справочников. Вы читаете ознакомительную версию урока, полноценные уроки находятся .

В нашей базе "Гастроном" (в режиме пользователя) откройте справочник "Единицы измерения":

Присмотритесь к его элементам. Видите жёлтые кружочки рядом с некоторыми из элементов? Вот эти элементы (у которых кружочки) и есть предопределенные данные .

Вообще же, если какой-либо элемент справочника является предопределенным (то есть на нём стоит жёлтый кружочек), то это особенный элемент.

Во-первых, это означает, что элемент был создан ещё на этапе конфигурирования программистом (в нашем случае это элементы с кодами 1, 2 и 3).

А, во-вторых, это значит, что этот элемент очень важен для функционирования программы. Что на него (вернее на его предопределенное имя) завязан какой-то код в базе данных.

Именно поэтому просто удалить такой элемент не получится. Попробуйте пометить его на удаление:

Давайте теперь перейдём в режим конфигурирования и посмотрим где же эти самые предопределенные элементы (в данном случае для справочника Единицы измерения) создаются:

Вот они все наши предопределенные элементы для справочника Единица измерения. Обратите внимание, что все предопределенные элементы имеют специальное имя, которое не отображается в режиме пользователя.

Для элемента с кодом 1 это имя Тонна, с кодом 2 - Грамм и так далее. Это имя называется предопределенным именем элемента и именно по этому имени можно обращаться к нему из кода (или из запроса в нашем случае).

Вы спросите почему же было не сделать единицы измерения просто перечислением с элементами Тонна, Грамм и Пачка? А всё потому, что в данном случае нам важно, чтобы справочник единицы измерения всегда содержал какие-то определенные элементы (тонна, грамм и пачка), но в то же время мы не хотим запрещать пользователю добавлять какие-то свои элементы (килограмм, штука и так далее). Вы читаете ознакомительную версию урока, полноценные уроки находятся .

Поэтому здесь безусловно больше подходят предопределенные элементы, чем перечисления.

А обращаться к нашим предопределенным элементам из запроса мы сможем используя уже знакомую нам функцию ЗНАЧЕНИЕ :

Пройдите тест

Начать тест

1. Значения перечислений задаются

2. Для хранения списка складов на фирме подойдёт тип

3. Для хранения списка единиц измерения на складе подойдёт тип

4. Для хранения ставок налога, список которых не должен изменяться пользователем, подойдёт тип

5. Чтобы обратиться в запросе к значению перечисления подойдёт функция

6. Для хранения ставок налога, список которых будет меняться пользователем, подойдёт тип

7. Предопределенные данные бывают у

Всем известно отличие предопределенных элементов от обычных: "Предопределенные элементы создаются в режиме "Конфигуратор" и не могут быть удалены в режиме 1С:Предприятия". В пользовательском режиме отличить предопределенный элемент от добавленных пользователями можно по специальной пиктограмме (см. следующий скриншот).

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

Этот элемент используется во многих модулях конфигурации. Так в документе "Поступление товаров и услуг" при выполнении проведения во всех регистрах, где есть измерение "Качество", подставляется значение предопределенного элемента. Далее приведен листинг заполнения таблицы проведения по регистру "ТоварыОрганизаций":

// ТОВАРЫ ПО РЕГИСТРУ ТоварыОрганизаций. НаборДвижений = Движения. ТоварыОрганизаций; Если ВидПоступления = Перечисления. ВидыПоступленияТоваров. НаСклад Тогда // Получим таблицу значений, совпадающую со структурой набора записей регистра. ТаблицаДвижений = НаборДвижений. Выгрузить() ; // Заполним таблицу движений. ОбщегоНазначения. ЗагрузитьВТаблицуЗначений(ТаблицаПоТоварам, ТаблицаДвижений) ; // Недостающие поля. ТаблицаДвижений. ЗаполнитьЗначения(Организация, " Организация " ) ; ТаблицаДвижений. ЗаполнитьЗначения(Неопределено , " Комиссионер " ) ; ТаблицаДвижений. ЗаполнитьЗначения(Справочники. Качество. Новый , " Качество " ) ; // Заполняем качество из предопределенного элемента

Таким образом, характерные черты предопределенных элементов и их назначение достаточно просты. Рассмотрим способ их хранения в таблицах базы данных и его отличие от обычных элементов.

Различия

В тестовой конфигурации создан справочник "Товары". В нем создана группа "Тестовые элементы". Содержимое группы Вы могли видеть на скриншоте в начале статьи. Для справочника "Товары" в SQL-базе данных имеется соответствующая таблица "_Reference37" со следующей структурой:

Но как определить соответствие реквизитов дереве конфигурации и полей в SQL-таблице?

Воспользуемся стандартным методом глобального контекста "ПолучитьСтруктуруХраненияБазыДанных()", который вернет нам таблицу значений с описанием струкутры таблиц.

В таблице значений "Поля" мы видим соответствие полей SQL-таблицы и реквизитов объекта в дереве метаданных. В нашем примере мы рассматриваем структуру справочника "Товары". У всех справочников есть стандартный реквизит "Предопределенный"булевого типа, который для предопределенных элементов установлен в ИСТИНА:

По таблице со структурой хранения справочника в базе данных мы однозначно можем сказать, что поле "Предопределенный" соответствует полю "IsMetadata". Если мы просмотрим содержимое таблицы "_Reference37" в SQL-базе, то увидим следующее:

В записи для предопределенного элемента значение поля "IsMetadata" установлено в "0x01", что соответствует флагу ИСТИНА. Для обычных элементов значение установлено в "0x00". В этом и заключается главное отличие предопределенных элементов от обычных. Все остальные поля хранятся в базе данных аналогично полям обычных элементов, добавленных пользователями.

Предопределенным элементам можно найти очень интересное предназначение. С их помощью можно запретить удалять/помечать на удаление группы элементов в справочнике и других объектах, где их можно добавить. Если мы попытаемся удалить или пометить на удаление группу "Тестовые элементы". то получим такие ошибки:

Таким образом, предопределенные элементы делают группу, в которую они помещены, тоже "предопределенной".

Завершение

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

Печать (Ctrl+P)

Работа с предопределенными значениями с помощью менеджера объекта

Получить предопределенное значение на стороне сервера «1С:Предприятия» можно с помощью менеджера соответствующего объекта. Строка, определяющая получаемый реквизит, имеет следующий вид:

ТипПредопределенногоЗначения.ИмяОбъектаМетаданных.Значение


ТипПредопределенногоЗначения – для получения предопределенных значений доступно указание следующих типов данных (написание во
множественном числе):
● Справочники,
● ПланыВидовХарактеристик,
● ПланыСчетов,
● ПланыВидовРасчета,
● Перечисления.
ИмяОбъектаМетаданных

● Значение – может быть одним из следующих:
● для перечислений указывается имя значения перечисления;

● ТочкиМаршрута.ИмяТочки – точка маршрута бизнес-процесса.
В случае, если требуется получить точку маршрута бизнес-процесса, строка, описывающая получаемое значение, будет выглядеть следующим образом:

БизнесПроцессы.ИмяОбъектаМетаданных.ТочкиМаршрута.ИмяТочкиМаршрута
Пример:


Вид = Перечисления.ВидыТоваров.Товар;
// Получение предопределенных данных справочника.
Элемент = Справочники.Валюта.Рубль;
// Точка маршрута бизнес-процесса
Точка = БизнесПроцесс.Согласование.ТочкиМаршрута.Одобрение;

Работа с предопределенными значениями С помощью функции ПредопределенноеЗначение()

В связи с тем, что на стороне клиента недоступны прикладные объекты, получение предопределенных реквизитов с помощью менеджеров объектов становится невозможным. Поэтому для их получения существует метод глобального контекста ПредопределенноеЗначение(). Параметром этого метода является строка, описывающая то, какое предопределенное значение требуется получить. Синтаксис описания предопределенного значения совпадает с синтаксисом оператора ЗНАЧЕНИЕ языка запросов.
Строка, определяющая получаемый реквизит, имеет следующий вид:

Рассмотрим составляющие этой строки подробнее:
ТипПредопределенногоЗначения – для получения предопределенных значений доступно указание следующих типов данных (написание в
единственном числе):
● Справочник ,
ПланВидовХарактеристик ,
● ПланСчетов ,
ПланВидовРасчета ,
● Перечисление,
● БизнесПроцесс .
● ИмяОбъектаМетаданных – указывается имя объекта метаданных так, как оно задано в конфигураторе.
● Значение – может быть одним из следующих

● для перечислений указывается имя значения перечисления;
● для получения предопределенного значения указывается его имя, как оно задано в конфигураторе;
● ТочкаМаршрута.ИмяТочки – точка маршрута бизнес-процесса;
● ПустаяСсылка – для получения пустой ссылки.
В случае необходимости получить значение системного перечисления параметр метода будет выглядеть следующим образом:
ИмяСистемногоПеречисления.ЗначениеСистемногоПеречисления.
Например:

ТипДиаграммы = ПредопределенноеЗначение(“ТипДиаграммы.ВогнутаяПоверхность “);
В случае если требуется получить точку маршрута бизнес-процесса, строка, описывающая получаемое значение, будет выглядеть следующим образом:
Пример:

// Получение значения перечисления.
Вид = ПредопределенноеЗначение (“Перечисление.ВидыТоваров.Товар”);
// Получение значения пустой ссылки.
ПустаяСсылка =
ПредопределенноеЗначение (“Документ.РасходнаяНакл.ПустаяСсылка”);
// Получение предопределенных данных справочника.
Элемент = ПредопределенноеЗначение (“Справочник.Валюта.Рубль”);
// Точка маршрута бизнес-процесса
Точка = ПредопределенноеЗначение (“БизнесПроцесс.Согласование. ТочкаМаршрута.Одобрение”);



Статьи по теме: