Связывание
главной и подчиненной форм
Связывание
главной и подчиненной форм осуществляется с помощью свойств
Основные поля
(Link Master Fields) и
Подчиненные поля
(Link Child Fields) элемента
управления
Подчиненная форма/отчет
(Subform/Subreport). Как мы уже сказали,
мастера форм автоматически заполняют эти свойства, основываясь на связях между
таблицами. Если связи не заданы, то связующими полями считаются поля в таблицах,
которые имеют одинаковые имена и совместимые типы данных. При этом связующее
поле в базовой таблице для главной формы должно быть ключевым.
Если при разработке
иерархической формы данные в главной и подчиненной формах окажутся не синхронизированными,
следует проверить значение свойств
Основные поля
(Link Master Fields)
и
Подчиненные поля
(Link Child Fields) и ввести или откорректировать
их значения:
-
Откройте главную форму
в режиме Конструктора.
-
Выделите элемент управления
Подчиненная форма/отчет
(Subform/Subreport) (проще всего сделать это,
описав с помощью мыши прямоугольник вокруг или пересекая этот элемент управления)
и откройте окно
Свойства
(Properties) для этого элемента.
-
В ячейку свойства
Подчиненные
поля
(Link Child Fields) следует ввести имя связующего поля из таблицы
или запроса, на котором базируется подчиненная форма.
-
В ячейку свойства
Основные
поля
(Link Master Fields) необходимо ввести имя связующего поля из таблицы
или запроса, на котором базируется главная форма.
-
Если вы не помните имена
полей в базовых таблицах или запросах, можно воспользоваться Построителем
для связывания полей. Нажмите кнопку Построителя справа от любого из упомянутых
свойств, и на экране появится диалоговое окно (рис. 9.38).
![](36.gif)
Рис. 9.38.
Определение связей между главной и подчиненной формами
В левой части
окна расположены раскрывающиеся списки для выбора связующих полей в главной
форме, в правой — для выбора связующих полей в подчиненной форме. Связь может
задаваться с помощью нескольких полей. Это может быть, если ключевое поле в
главной таблице составное. Построитель позволяет задать максимум три поля и,
как правило, этого хватает. В противном случае нужно просто вписать недостающие
поля в значения свойств, разделив их точкой с запятой. Важно только, чтобы поля
в каждом из данных свойств перечислялись в одинаковом порядке.
В предложенных
списках содержатся все поля базовых таблиц или запросов. Это означает, что связующие
поля необязательно должны присутствовать в формах, они обязаны присутствовать
в источнике данных формы.
Содержание раздела