TableRef
- Класс
TableRef
- Поддерживает документацию
- нет
- Поддерживает extras
- да
Ссылка на ключ в другой таблице (TableRef) позволяет устанавливать вспомогательные связи между таблицами, которые могут использоваться операциями, например, для заполнения выпадающих списков. Связь имеет следующие свойства:
- tableFrom: исходная сущность. Это та сущность, в которой связь объявлена.
- columnFrom: исходная колонка. В данном случае это псевдо-колонка (например, kladr::search::street). Если вы хотите установить связь к существующей колонке, это необходимо сделать непосредственно в определении колонки.
- tableTo: целевая сущность.
- columnTo: целевая колонка. Может быть не указана, тогда автоматически используется первичный ключ целевой сущности.
- view: имя представления в целевой сущности, которое используется для выбора элементов. По умолчанию — *** Selection view ***.
Ссылки располагаются в дереве проекта в папке References внутри сущности. Имя ссылки формируется автоматически по имени колонки и целевой сущности.
Ссылки сериализуются в yaml-файл сущности в секцию references. В качестве ключа указывается columnFrom. Свойства tableTo и columnTo сериализуются в одно поле to через точку. Если кроме поля to ничего нет, можно имя поля опустить.
Примеры
users: references: kladr::search::city: to: addresses.dummy view: City from KLADR
Здесь создаётся ссылка с tableFrom = users, columnFrom = kladr::search::city, tableTo = addresses, columnTo = dummy, view = City from KLADR (такое представление должно существовать в сущности addresses, иначе будет предупреждение при синхронизации).
buildings: references: buildingID: buildings
Здесь создаётся ссылка с tableFrom = buildings, columnFrom = buildingID, tableTo = buildings, columnTo = ID (первичный ключ у таблицы buildings), view = *** Selection view *** (по умолчанию).