Программирование >>  Разработка пользовательского интерфейса 

1 ... 46 47 48 [ 49 ] 50 51 52 ... 147


ADD TABLE C:\MYPROJECT\MODEL.DBF

USE Model

В следующем примере поиск таблицы Body производится в текущей базе данных:

USE Body

Если таблица Body не принадлежит текущей базе данных, ее поиск вне базы будет происходить в пути по умолчанию.

Всегда можно указать полный путь к файлу таблицы, чтобы открывать ее вне зависимости от ее принадлежности к какой-либо базе данных, например, если вас не устраивают изменения в местонахождении таблиц. Однако ссылки на таблицу только по ее имени могут значительно повысить производительность приложения, поскольку в Visual FoxPro доступ к именам таблиц из базы данных осуществляется гораздо эффективней, чем по полному пути файла.

Когда вы создаете базу данных, Visual FoxPro создает и открывает для монопольного использования файл с именем БД и расширением DВС (DataBase Container). В этом файле хранится вся информация о базе данных, включая имена файлов и объектов, ассоциированных с ней. Сами объекты верхнего уровня типа таблиц или полей в файле DBC не хранятся. Хранятся только пути к файлам таблиц.

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

Схема базы данных - это визуальное представление структур таблиц и установленных отношений между ними. Схема открытой базы данных отображается в окне Конструктора баз данных.

В Конструкторе баз данных панель инструментов Database можно использовать для создания новой таблицы, добавления существующей таблицы в базу данных, удаления таблиц из базы данных, изменения структуры таблицы. Здесь же вы можете редактировать хранимые в базе процедуры.

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

Конструктор баз данных является концептуальным представлением схемы базы данных, однако вам может потребоваться просмотреть содержимое файла базы данных непосредственно. Можно сделать это, выполнив команду USE для файла DBC неоткрытой базы данных. В следующем примере открывается окно просмотра, куда выводится содержимое файла базы данных Auto Store в табличном виде.

CLOSE DATABASE Auto Store

USE AUTO STORE.DBC EXCLUSIVE

BROWSE

Не используйте команду BROWSE для модификации файла базы данных, если вы не знакомы со структурой файла DBC. Любая ошибка при изменении файла DBC может разрушить базу данных и привести к потере информации.

В каждом файле DВС имеется поле примечаний с именем User, в котором вы можете хранить собственную информацию о каждой записи базы данных. Вы можете также расширить файл DВС, добавив туда поля, чтобы удовлетворить свои собственные потребности разработчика. Для изменения структуры файла DBC вы должны открыть его для монопольного использования.

Как добавить поле к файлу DВС?

1. Откройте файл DВС для монопольного доступа командой USE.

2. Выполните команду MODIFY STRUCTURE.

В следующем примере открывается Конструктор таблиц, где вы можете добавить поле в файл

AUTO STORE.DBC:

USE AUTO STORE.DBC EXCLUSIVE MODIFY STRUCTURE

При добавлении нового поля в файл базы данных начинайте имя этого поля с символов U для обозначения поля пользователя. Это поможет вам избежать конфликтов с любыми возможными изменениями структуры файла DBC.

Не изменяйте системные поля в файле DBC. Любые такие изменения могут нарушить



целостность базы данных.

Вы можете проверить целостность базы данных с помощью команды VALIDATE DATABASE. В следующем примере файл базы данных Auto Store проверяется на целостность:

OPEN DATABASE Auto Store EXCLUSIVE VALIDATE DATABASE

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

Использование словаря данных

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

Длинные имена таблиц.

Комментарии для каждого поля, таблицы и базы данных.

Длинные имена полей.

Заголовки полей, отображаемых в окнах просмотра и в виде заголовков столбцов сетки.

Значения полей по умолчанию.

Первичные ключи и ключи -кандидаты.

Правила на уровне полей и правила на уровне записей.

Триггеры.

Постоянные отношения между таблицами базы данных.

Хранимые процедуры.

Связи с удаленными источниками данных.

Локальные и удаленные представления.

Некоторые элементы словаря, такие как длинные имена полей, первичные и ключи-кандидаты, значения по умолчанию, правила на уровне полей и записей, триггеры, хранятся в файле DBC, но становятся доступны в процессе создания таблицы или представления.

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

Для создания, редактирования или удаления хранимой процедуры в Project Manager выделите имя базы данных, выберите в списке пункт Stored Procedures, затем нажмите одну из кнопок: New, Modify или Remove.

Для этой же цели в Конструкторе баз данных выберите из меню Database команду Edit Stored Procedures.

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

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

Поддержание ссылочной целостности предусматривает построение набора правил для сохранения установленных отношений между таблицами при вводе или удалении записей. Аппарат поддержания ссылочной целостности позволяет избежать следующих неприятных ситуаций:

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

Изменения значений в главной таблице, если это изменение приведет к появлению не связанных ( одиночных ) записей подчиненной таблицы.



Удаления записей из главной таблицы, если для нее существуют соответствующие записи в подчиненных таблицах.

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

Для работы с Построителем ссылочной целостности откройте Конструктор баз данных. В меню Database выберите Referential Integrity.

Если вы используете Построитель ссылочной целостности, Visual FoxPro сохраняет генерируемый код в качестве триггеров, которые ссылаются на хранимые процедуры. Вы можете просмотреть код этих процедур, открыв с помощью текстового редактора хранимые процедуры для базы данных, как это было описано выше, но будьте очень осторожны при попытке его модернизации. Может, вы лучше не будете его редактировать?

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

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

Автоматически использовать установленные условия объединения в Конструкторах запросов и представлений.

В Конструкторе баз данных визуально отображать связанные индексы таблиц.

В Конструкторе среды окружения данных (Data Environment Designer) отображать установленные по умолчанию связи для форм и отчетов.

Использовать аппарат поддержки ссылочной целостности.

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

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

Как создать постоянные отношения между таблицами?

В Конструкторе баз данных выберите индекс, который вы хотите связать, и перетащите его на индекс связываемой таблицы, или включите предложение FOREIGN KEY в команду CREATE TABLE или команду ALTER TABLE.

Если после этого вы посмотрите на схему базы данных в Конструкторе БД, то увидите линию, соединяющую две таблицы и обозначающую новую постоянную связь.

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

Для удаления постоянного отношения между таблицами в Конструкторе баз данных выделите щелчком линию, соединяющую таблицы. Толщина линии увеличится, отмечая выбор отношения между таблицами. После этого нажмите клавишу Del.

Каждая база данных Visual FoxPro содержит свойства Comment и Version. Вы всегда можете узнать содержание этих свойств с помощью функции DBGETPROP().

В следующем примере на экран выводится номер версии базы данных Auto Store:

? DBGETPROP(Auto Store, DATABASE, VERSION)

Возвращаемое значение является номером версии файла DBC и доступно только для чтения. Программно ввести комментарий в базу данных можно с помощью функции DBSETPROP(). Для этого используйте опцию COMMENT в функции DBSETPROP(). В следующем примере вводится новый комментарий для базы данных Auto Store:



1 ... 46 47 48 [ 49 ] 50 51 52 ... 147

© 2006 - 2025 pmbk.ru. Генерация страницы: 0
При копировании материалов приветствуются ссылки.
Яндекс.Метрика