12156

ПРИЛОЖЕНИЯ С НЕСКОЛЬКИМИ СВЯЗАННЫМИ ТАБЛИЦАМИ

Лекция

Информатика, кибернетика и программирование

ПРИЛОЖЕНИЯ С НЕСКОЛЬКИМИ СВЯЗАННЫМИ ТАБЛИЦАМИ Рассмотрим принципы построения приложения с несколькими связанными друг с другом таблицами. 8.1 Связь головной и вспомогательной таблиц Две таблицы могут быть связаны друг с другом по ключу. Одна из этих связанных табл...

Русский

2013-04-24

31.5 KB

3 чел.

ПРИЛОЖЕНИЯ С НЕСКОЛЬКИМИ СВЯЗАННЫМИ ТАБЛИЦАМИ

Рассмотрим принципы построения приложения с несколькими связанными друг с другом таблицами.

8.1 Связь головной и вспомогательной таблиц

Две таблицы могут быть связаны друг с другом по ключу. Одна из этих связанных таблиц является головной (master), а другая – вспомогательной, детализирующей (detail).

Например, мы хотим построить приложение, в котором имеется таблица Proba, содержащая список сотрудников некоторой фирмы, и хотим, чтобы пользователь, перемещаясь по этой таблице, видел не только список сотрудников, но и адресные данные каждого сотрудника, которые содержатся в таблице Adress. В этих таблицах совпадают значения полей Number для текущей записи. В этом случае головной является таблица Proba, вспомогательной – таблица Adress, а ключом, определяющим их связь, являются  поля Number из обеих таблиц.

При построении приложения с несколькими связанными таблицами необходимо разместить на форме столько комплектов компонентов Table, DataSource и средств отображения данных, сколько таблиц будет в приложении. Каждый комплект настраивается на свою таблицу. Головная и вспомогательная таблицы должны быть индексированы по тому полю, которое будет ключом для связи таблиц. Сама связь осуществляется в несколько этапов:

  1.  вначале временно разрываем связь с базой данных в комплекте, связанном со вспомогательной таблицей;
  2.  далее в свойстве MasterSource компонента Table2, настроенного на вспомогательную таблицу, устанавливаем имя головной таблицы;
  3.  щелкнув на свойстве MasterFields, открываем окно редактора связей полей (Field Link Designer). В нем слева в окне Detail Fields расположены имена полей вспомогательной таблицы, но только те, по которым таблица индексирована. Именно поэтому надо индексировать таблицу так, чтобы индекс включал ключевое поле связи. Справа в окне Master Fields расположены поля головной таблицы. В одном и в другом окне необходимо выделить ключевое поле и зафиксировать действия щелчком на кнопке Add. При наличии составного ключа операцию необходимо повторить для всех полей ключа. Завершить работу с редактором связей полей можно по щелчку на кнопке OK.

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

8.2 Поля просмотра (lookup fields)

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

Для ввода таких полей необходимо вызвать редактор полей вспомогательной таблицы и создать новое поле (выбор контекстного меню редактора полей New Field, см. Создание вычисляемого поля). Имя этого нового поля должно отличаться от имен других полей, а тип должен соответствовать типу того поля в таблице просмотра, которое необходимо просмотреть. Для строк и некоторых других типов полей надо еще указать размер поля.

После того, как новое поле определено, в группе радиокнопок Field type необходимо нажать кнопку Lookup и в выпадающем списке Key Fields выбрать ключевое поле (или поля) в таблице, в которой создается новое поле. Это то поле или поля, по которому надо будет связываться с другой таблицей. В  выпадающем списке Lookup Keys необходимо выбрать ключевое поле (или поля) просматриваемой таблицы. А затем, в выпадающем списке Result Field выбрать просматриваемое поле.

Остается только задать для нового поля в Инспекторе объектов свойства, необходимые для осуществления связи с таблицей (DisplayLabel, DisplayValues). При этом, значения таких полей, как FieldKind, KeyValues, LookupDataset, LookupKeyField и LookupResultField  будут определены автоматически.

Еще одно свойство поля просмотра LookupCache определяет, будут ли значения просматриваемого поля кэшироваться, или просмотр будет осуществляться при каждом изменении текущей записи. Если просматриваемая таблица (та, из которой берутся данные) не изменяется или изменяется редко, лучше задать LookupCache = true. Это существенно сократит затраты времени на просмотр, который будет осуществляться не в таблице, а в кэше, который загружается один раз при открытии базы данных. Но если в процессе работы просматриваемая таблица изменяется, а LookupCache = true, то результат просмотра может быть неверным. В этих случаях надо вызывать метод RefreshLookupLis, чтобы обновить хранящийся список.

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

Поля просмотра имеют одну интересную особенность. Дело в том, что для них предусмотрены специальные компоненты: DBLooupListBox и DBLookupComboBox – список и выпадающий список. Если вы поместите на форму один из этих компонентов, установите у него свойство DataSource, соответствующее таблице, имеющей поля просмотра, а в свойстве DataField выберите одно из полей просмотра, то значения просматриваемого поля сразу отобразятся в списке. При этом не надо заботиться о загрузке в список значений, как это приходится делать со списками DBListBox и DBComboBox.


 

А также другие работы, которые могут Вас заинтересовать

10404. Правовое государство и гражданское общество 29 KB
  Правовое государство и гражданское общество. Понятие правового государства тесно связано с понятием демократии. В ст.1. гл.1 российской Конституции сказано: Российская Федерация Россия есть демократическое федеративное правовое государство с республиканской формо...
10405. Парламент и парламентаризм 37.5 KB
  Парламент и парламентаризм. Парламент англ. parliament от франц. parlemeni от parler говорить высший представительный орган власти. Впервые был образован в Англии в XIII в. как орган сословного представительства, реальное значение приобрел после буржуазных революций XVII-XVIII вв. Па
10406. Сущность, основные черты и типы демократии 30.5 KB
  Сущность основные черты и типы демократии. В переводе с греческого термин демократия означает власть народа. Полное и четкое определение понятия демократия сформулировать достаточно сложно тем не менее можно выделить ряд характерных признаков присущих всем де...
10407. Современная система международных отношений: проблемы и противоречия 37.5 KB
  Современная система международных отношений: проблемы и противоречия. Международные отношения более сложное явление чем внешняя политика Это совокупность экономических политических идеологических правовых военных информационных дипломатических и других
10408. Глобальный и региональный аспекты международной безопасности в мире 42 KB
  Глобальный и региональный аспекты международной безопасности в мире. В наши дни в условиях все возрастающей взаимозависимости и взаимосвязи государств на мировой арене становится необходимым изучение не только политических систем отдельно взятых государств но и м...
10409. Понятие национального интереса. Приоритеты внутренней и внешней политики РФ. 40 KB
  Понятие национального интереса. Приоритеты внутренней и внешней политики РФ. Современный мир характеризуется переходом к многополярному мироустройству. Растет многообразие политического экономического и культурного развития стран идет поиск на национальном и ре...
10410. Проблемы политической социализации личности 26 KB
  Проблемы политической социализации личности. Среди множества факторов способствующих сохранению политической системы социализация индивида занимает важное место поскольку ни одна система не сможет достигнуть достаточного уровня интеграции и стабильности если ...
10411. Политическое поведение личности как категория в политологии 35.5 KB
  Политическое поведение личности как категория в политологии. В самом общем виде действие социальных норм состоит: а в установлении типов образцов общественно значимого поведения; б в установлении границ в пределах которых индивидуальное поведение служит осуществл...
10412. Проблемы политического лидерства в обществе. Основные типы политических лидеров 29 KB
  Проблемы политического лидерства в обществе. Основные типы политических лидеров. Понятие лидер€ происходит от английского leader что означает ведущий управляющий другими людьми. Становление и функционирование лидеров объективное и универсальное явление. С понят...