Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Плещёв ИП 2010-04-04 doc.doc
Скачиваний:
108
Добавлен:
13.05.2015
Размер:
5.96 Mб
Скачать

9.4.3. Методы

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

Непосредственный доступ к базам осуществляется через объекты доступа к данным (Data Access Objects ‑ DAO), которые хранятся в биб­лиоте­ке DAO350.DLL. Чтобы воспользоваться DAO, необходимо вы­пол­нить команду Project/Referencesи выбрать далее строкуMicrosoft DAO 3.51 Object Library.

Структура вложенности коллекций объектов DAO

DBEngineобъект самого верхнего уровня в модели DAO.

Errors (Error) ‑ описание ошибок доступа к базе.

Properties (Property) ‑свойства объектов вышестоящего уровня.

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

Databases (Database) - представляет открытую базу данных.

Connections (Connection) - подключение к базе данных ODBC.

Groups (Group) - представляет группу учетных записей пользователей, которые имеют общие разрешения при открытии объекта Workspace для защищенной рабочей группы.

Users (User) - содержит все сохраненные объекты User объекта Workspace или Group.

Properties(Property) ‑ свойства объектов вышестоящего уровня.

Структура объекта Database

Database представляет собой открытую базу данных. При открытии существующего объекта Database или при создании нового объекта в объекте Workspace база данных автоматически добавляется в семейство Databases. Объект Database, закрытый с помощью метода Close, удаляется из семейства Databases, но не удаляется с диска. Перед закрытием объекта Database необходимо закрыть все открытые объекты Recordset. При ссылках на объект Database используют его порядковый номер в семействе или значение свойства Name (имя) в одной из следующих синтаксических конструкций: Databases(0), Databases(“имя>”), Databases![<имя>].

Можно открыть базу данных несколько раз, создавая повторяющиеся имена в семействе Databases. После этого следует присвоить объекты Database объектным переменным и ссылаться на объекты по именам переменных.

Recordsets (Recordset) ‑представляет собой открытую таблицу базы.

Fields (Field) - представляет собой поле открытой таблицы.

Properties(Property) ‑ свойства объектов вышестоящего уровня.

TableDefs (TableDef) -содержит все объекты TableDef базы данных. Работа с определением таблицы проводится с помощью объекта TableDef и его методов и свойств. При ссылках на объект TableDef используют его порядковый номер в семействе или значение свойства Name (<имя>):

TableDefs(0) или TableDefs(“<имя>”) или TableDefs![<имя>]

Indexes (Indexes) - содержит индексы. При доступе к объектам Recordset типа таблицы порядок записей определяется свойством Index объекта. В значении этого свойства следует указывать значение свойства Name существующего объекта Index из семейства Indexes объекта TableDef, представляющего собой базовую таблицу объекта Recordset. Применение методов Append или Delete к семейству Indexes возможно только при значении True свойства Updatable вмещающего объекта TableDef. Созданный новый объект Index должен быть добавлен в семейство Indexes объекта TableDef с помощью метода Append.

Fields (Field), Properties (Property)

Relations (Relation) -используют для создания новых связей и просмотра существующих в базе данных. Чтобы добавить объект Relation в семейство Relations, следует сначала создать этот объект с помощью метода CreateRelation, а затем добавить его в семейство Relations с помощью метода Append. Для удаления объекта Relation из семейства следует вызвать метод Delete. При ссылках на объект Relation используют его порядковый номер в семействе или значение свойства Name (<имя>):

Relations(0), Relations(“<имя>”), Relations![<имя>].

Fields (Field), Properties (Property)

Indexes (Index) ‑ содержит индексы.

Fields (Field),Properties (Property)

QueryDefs (QueryDef) - содержит запросы. Для создания нового объекта QueryDef следует использовать метод CreateQueryDef. Если задать пустую строку в аргументе имя или в свойстве Name, то будет создан не постоянный, а временный объект QueryDef. При ссылках на объект используют его порядковый номер в семействе или значение свойства Name (<имя>):

QueryDefs(0), QueryDefs(”<имя>”), QueryDefs![<имя>]

Parameters (Parameter) - содержит параметры QueryDef.

Fields (Field), Properties (Property)

Containers (Container) - содержит контейнеры.

Documents (Document) - содержит сведения об экземплярах встроенных объектов типа, определяемого объектом Container.

Properties (Property) ‑ свойства объектов вышестоящего уровня

Использование Recordset

Свойство Recordsetможно рассматривать как объект, связанный с воображаемой таблицей, к которой подключен объект Data.

Объект создается методом OpenRecordset(<источник>[, <тип>])после открытия базы данных методомOpenDatabase(<база>) или методомCurrentdbдля уже открытой текущей базы данных. Поскольку эти методы являются функциями, то перед их использованием нужно объявить переменные, соответствующие типамDatabaseиRecordset. Источником может быть имя таблицы, запроса или текст команды запроса.

Параметр <тип> метода OpenRecordsetопределяет тип набора: DbOpenTable (табличный), dbOpenDynamic (динамический в рабочей об­лас­ти ODBCDirect), dbOpenDynaset (динамический), dbOpenSnapshort (мо­мен­тальный снимок), dbOpenForwardOnly (продвижение только вперед).

Для сокращения записи программы можно использовать команду установки области умолчания для объекта:

With <имя объекта> ‘установка начала области умолчания объекта

... ‘команды

End With ‘конец области умолчания

Внутри области умолчания свойства или методы начинаются непос­ред­ствен­но с точки (.MoveNext).

Допускаются следующие виды обращения к значению поля базы:

<имя объекта Recordset>[.Fields]({“<имя поля>”|<номер поля >})[.Value]

<имя объекта Recordset>!<имя поля записи>

<имя объекта Recordset>![<имя поля записи>]‘ в имени есть пробелы

Пример. rs.Fields(“Fam”)=”Иванов” или rs!Fam=”Иванов”.

Свойство RecordCountсодержит число записей в наборе.

Примерcоздания объектов Data и Recordset с именами Db, Rs,Rb

Dim Db as Database, Rs as DAO.Recordset, Rb as DAO.Recordset

Set Db=OpenDatabase(App.Path+“\Стройки.mdb”) ‘открытие базы строек

Set Rs=db.OpenRecordset(“select * From [Zakazhiki] Order By [Nz]”) ‘запрос

Set Rb=db.OpenRecordset(“Goroda”) ‘открытие справочника городов

Debug.Print Rs.Fields(“Kg”),Rs!Ng ‘вывод кода и наименования города

Print “Число заказчиков ”,Rs.RecordCount ‘вывод числа строек

После создания объекта Recordset можно получить доступ к данным.

Перемещение по таблице

Методы MoveNext(следующая запись),MovePrevious(предыдущая запись),MoveLast(последняя запись), MoveFirst(первая запись).

Примеры вывода записей из таблицы и запроса

Dim db As Database ‘объявление переменной базы

Private Sub Form_load ‘заголовок процедуры загрузки формы

Set Db=Opendatabase(App.Path+”\Стройки.mdb ”) ‘открытие базы

End Sub

Private Sub Command1_Click() ‘процедура распечатки справочника

Dim Rs As DAO.Recordset ‘объявление переменной набора Recordset

Set Rs=db.OpenRecordset(“Zakazhiki”) ‘создание Recordset Rs

Do Until rs.EOF ‘заголовок цикла чтения таблицы

Debug.Print rs.Fields(“Kz”)&rs!Nz ‘вывод на экран записи

Rs.MoveNext ‘переход к следующей записи набора

Loop

Rs.Close ‘закрытие набора Rs

End Sub

Private Sub Command2_Click() ‘процедура вывода запроса из базы

Dim rs As DAO.Recordset

Set rs = db.OpenRecordset(“Select * from Стройки “) ‘формирование запроса

Do While Not rs.EOF: Debug.Print rs(“ns“).Value: rs.MoveNext: Loop ‘вывод

rs.Close: db.Close ‘закрытие набора и базы

End Sub

Для добавления записив набор записей используется методAddNew. Метод вызывается в виде, например: data1.Recordset.AddNew. Метод создает пустую запись в оперативной памяти, а не в базе, очищает все поля формы, связанные c базой данных, давая возможность вводить значения для новой записи. При программном режиме следует присвоить полям значения, используя объект Fields, например: rs.Fields(“Nt”)=”Сахар” или rs!Nt=”Сахар”. Если нужно сразу запомнить все изменения в записи, вызывается методUpdate, имеющий синтаксис, аналогичный синтаксису метода AddNew. Если тип набора ‑ мо­мен­таль­ный снимок, то обновлять базу данных запрещено.

Для удаления записииспользуется методDelete.

Пример

Private Sub cmdDelete_Click() ‘обработка кнопки “Удалить”

With datPrimaryRS.Recordset ‘установка объекта по умолчанию

.Delete ‘удаление текущей записи

.MoveNext ‘переход к следующей записи

If .EOF Then .MoveLast ‘переход на последнюю запись

End With ‘конец области умолчания

End Sub ‘окончание процедуры

Для корректировки полязаписи выполните ряд действий.

  1. Установите текущей нужную запись.

  2. Выполните метод EditобъектаRecordset.

  3. Присвойте новые значения корректируемым полям, например: rs.Fields(“Nz”)=”АО Уралмаш” или rs!Nz=”АО Уралмаш”.

  4. Сохраните обновленную запись методом UpdateобъектаRecordset.

Для сортировки набораобычно используются индексы или команды SQL с фразой Order By. Индекс может быть создан заранее при создании таблицы или программным способом.

Пример

rs.Recordset.Index=”kz” ‘установка индекса под именем Kz

rs.Recordset.MoveFirst ‘переход на логически первую запись

rs.Recordset=”Select * From [Zakazhiki] order by Kz” ‘запрос-сортировка

Последовательный метод поиска записи Find

FindFirst “<условие поиска>”, FindLast“<условие поиска>”- поиск первой или последней записи, удовлетворяющей условию.

Пример. Rs.FindFirst “[Ng]=’Екатеринбург’”

FindNext, Findprevious‑ переход на следующую или предыдущую запись, удовлетворяющую условию, соответственно.

Результат поиска содержится в свойстве NoMatchобъекта Recordset: False ‑ объект найден, и он становится текущим;

True ‑ объект отсутствует в наборе, и текущая запись не изменяется.

Прямой метод поиска записи Seek

Этот метод более эффективен, так как использует индексы.

Вызов метода имеет вид:

Seek<оператор сравнения (<, <=, >, >=, =)>, <значение>

Перед поиском нужно установить соответствующий индекс, используемый при поиске.

Пример

Private Sub Form_Load() ‘процедура загрузки формы

Private db As DataBase ‘объявление переменной базы данных

Private rs As DAO.RecordSet ‘объявление переменной набора

End Sub

Private Sub cmdSeek_Click() ‘процедура обработки кнопки поиска

Set Rs.Index=”Familij” ‘установка индекса под именем “Familij”

Set Rs.Seek “=”, Fam.Text ‘значение фамилии введено в поле Fam

If rs.NoMatch Then ‘запись отсутствует

MsgBox (“Фамилия “+Fam.Text+”отсутствует!”)

Else

MsgBox(rs!Fam&rs!Gr&rs!Adr&rs!Oklad) ‘вывод полей найденной записи

End If

End Sub

Определение индекса с помощью объекта TableDef

При выполнении операции поиска Seek над объектом Recordset табличного типа нужно знать доступные индексы. Для этого используется свойство Indexes объекта TableDef.

Пример

Private Sub Form_Load() ‘процедура загрузки формы

Private db As DataBase ‘объявление переменной базы данных

Private rs As DAO.Recordset ‘объявление переменной набора

Set db=OpenDatabase(App.Path+“\Строительство.mdb” ) ‘открытие базы строек

End Sub

Private Sub cmdShowInd_Click() ‘обработка кнопки вывода индексов

Dim td As TableDef ‘объявление переменной объекта TableDef

Dim ind As Index ‘объявление переменной объекта Index

Dim f As Field ‘объявление объекта Field

Set td=db.TableDefs(“uhet stroek”) ‘открытия объекта TableDef

For Each ind In td.Indexes ‘цикл просмотра индексов в коллекции Indexes

Debug.print Ind.Indexes ‘вывод на экран имени очередного индекса

For Each f In ind.Fields

Debug.print “ поле “&f.Name ‘вывод на экран имени поля индекса

Next

Next

End Sub

Сохранение положения записи с помощью свойства Bookmark

С помощью свойства Bookmark можно запоминать адреса нужных записей в виде закладок. Для этого:

  1. Перейдите на запись, которую хотите отметить закладкой.

  2. Присвойте свойству Bookmark объекта Recordset уникальную закладку в виде строки.

  3. Когда нужно вернуться к отмеченной записи, установите ее закладку в свойстве Bookmark.

Механизм транзакций

С помощью объекта Workspace устанавливается сеанс работы поль­зо­вателя с процессором базы данных. Эти объекты создаются в случаях, ког­да используются транзакции или для безопасности. Транзакция ‑ это процесс перевода состояния базы из одного целостного в другое целостное состояние, что повышает надежность хранения информации в базе. Для создания транзакции необходимо:

  1. Использовать метод BeginTransобъекта Workspace, который зап­ре­щает запись данных в базу до полного завершения транзакции (Workspaces(0).BeginTrans).

  2. Если любая операция с базой закончилась аварийно или нужно отменить все операции, то выполните метод RollBackобъекта Workspace(Workspaces(0).RollBack).

  3. Для успешного завершения транзакции выполните метод CommitTrans (Workspaces(0).CommitTrans).

Связь между таблицамисоздается методомCreateRelationобъекта Database:

Set <переменная>=db.CreateRelation ([<имя связи>],[<имя родительской таблицы>],[<имя дочерней таблицы>],[<параметры>])