Справочник функций

Ваш аккаунт

Войти через: 
Забыли пароль?
Регистрация
Информацию о новых материалах можно получать и без регистрации:

Последние темы форума

Показать новые сообщения »

Почтовая рассылка

Подписчиков: 11642
Последний выпуск: 19.06.2015

Основы работы с базами данных

Умение обращаться с файлами данных - чуть ли не одна из самых важных ступений в обучении программированию на Visual Basic! Здесь я постараюсь выложить только самые основные приёмы работы с объектом Data.

Прежде чем начать использовать базу данных её нужно сначала создать ;)!

1.Создайте стандартный проект.

2.Кликните на ToolBox'e на кнопку Data и натяните на форму так, чтобы полоска была не очень широкой и в самом низу формы.

3.Теперь создайте на форме четыре кнопки и назовите их (по порядку создания): cmdAdd, cmdDelete, cmdUpdate, cmdExit. Свойствам Caption дайте эти же имена, только без "cmd".

4.Создайте на форме три текстовых поля одинаковой длины.

5.Теперь надо связать объект Data с какой-нибудь базой данных. С какой? С той которая есть у всех владелцев VBasic'a - biblio.mdb! Активируйте объект Data и в свойствах, в DatabaseName выберите этот файл. Теперь там же, но в поле RecordSource надо выбрать раздел "Authors". Этим мы выберем только нужную часть базы данных.

6.Выделите первое текстовое поле и в свойствах, в DataSource выберите единственную в списке, созданную нами базу данных Data1, т.е. тем самым мы связываем это текстовое поле с объектом Data1. А в поле свойств DataField выберите "Au_ID". Теперь задача этого поля отображать идентификационный номер каждого автора! То же самое проделайте со следующими двумя другими полями, но в DataField вместо "Au_ID" выберите "Author" и "Year Born".

Поздравляю! Если Вы ещё этого никогда не делали, то знайте - Вы написали первую в своей жизни простенькую программку для отображения содержания базы данных!!! А теперь научимся редактировать её. Итак, главное редактирование - это занесение записей и удаление их.

7.Щёлкните два раза на кнопку Add и введите:

Private Sub cmdAdd_Click() 
   Data1.Recordset.AddNew 
   'Все поля, которые могут быть отредактированы будут очищены 
   'и подготовлены, поле Year Born будет установленно на 0, 
   'т.к. оно должно иметь какое-то значение 
   'поле Au_ID не будет очищено вообще, а изменено на самую 
   'последнюю позицию 
End Sub 

8.Следующая кнопка сохраняет внесённые изменения в базе данных. Сделайте двойной клик по кнопке Update и введите:

Private Sub cmdUpdate_Click() 
    'сохраняем ... 
    Data1.UpdateRecord 
    'без следующей строки после сохраниения в полях 
    'автоматически появились бы самые первые записи. 
    'поэтому закладке присваеваем идентификатор последней 
    'изменённой записи и в полях остануться ваши записи 
    Data1.Recordset.Bookmark = Data1.Recordset.LastModified 
End Sub 

9.Теперь самое лёгкое - удаление записей!!! Ведь правильно говорят - "Ломать - не строить!" :-))). Делаем двойной щелчок по кнопке Delete и вводим:

Private Sub cmdDelete_Click() 
  'чтобы выполнить последовательность инструкций над 
  'одиночным объектом Data1,  не перечисляя его каждый 
  'раз, используем инструкцию With 
  With Data1.Recordset 
    .Delete 
    .MoveNext 
    If .EOF Then .MoveLast 
  End With 
End Sub 

10.И теперь для кнопки Exit просто введите:

Private Sub cmdExit_Click() 
    End 
End Sub 

Всё! А тепeрь Вы создали почти настоящую программу с базой данных!!!

10.Запустите проект. Нажмите на правую кнопку >. Содержание полей сменилось! Теперь нажмите на правую кнопку >|. В полях появились самые последние записи! То же самое будет происходить при нажатии на левые кнопки |11.Теперь нажмите кнопку "Add".

12.Первое поле НЕ испраляйте, во второе ввидите, например, ваше имя, а в третье год рождения.

13.Теперь сохраните эту запись, нажав кнопку "Update".

14.Знайте, ваша запись теперь сохранена на самом последнем месте! Можете снова "прогуляться" по записям и вернутся наконец с помощью правой кнопки >|. Ваша запись на месте.

15.Теперь нажмите на кнопку Delete... запись исчезла! НО! В этом случае мы НЕ можем удалять записи сделанные не нами.

Ну, вот и готово! А теперь я расскажу немного о создании некотрых удобств с работой с базой данных. Например, представим себе, что Вы, просматривая нашу базу данных, заметили имя автора где-то в середине и через некоторое время должны вернуться к этой записи... Не пролистывать же нам снова окло тысячи имён!!! Для этого можно создавать так называеимые закладки!

16.создайте на форме ещё две кнопки с именами cmdMBM и cmdSMB со следующими надписями: Make the Bookmark и Show the Bookmark.

17.Теперь в разделе формы General Declarations объявите переменную, которая будет содержать идентификатор актуальной записи:

'переменная должна быть объявлена, как Variant поскольку 
'значения закладки могут быть как числовые, так и строковые 
Dim BM As Variant 

18.Теперь делаем двойной щелчок по кнопке cmdMBM и вводим:

Private Sub cmdMBM_Click() 
    'получаем идентификатор актуальной записи 
    BM = Data1.Recordset.Bookmark 
End Sub 

19.Теперь делаем двойной щелчок по кнопке cmdSBM и вводим:

Private Sub cmdSBM_Click() 
    'присваеваем закладке идентификатор нужной записи 
    Data1.Recordset.Bookmark = BM 
End Sub 

20.Снова запустите проект и прощёлкайте несколько записей.

21.Нажмите кнопку "Make the Bookmark". Так, теперь пролистайте ещё дальше или вернитесь, вобщем уйдите от этой записи.

22.Щёлкните на кнопку "Show the Bookmark".

В полях появились записи, на которые Вы и поставили закладку!

А теперь я расскажу немного о поисках записей в базе данных. Представьте себе, что Вам нужно найти конкретное имя автора из тысяч других... WOW!!! :-)) Представили? Ну, так вот листать - вроде совсем не интересно... Нужно воспользовать одним из способов нахождения :

FindFirst, FindLast, FindNext или FindPrevious. В следующей таблице представлены ихзначения:

МетодПояснение
FindFirstИщет первую запись в БД
FindLastИщет последнюю запись в БД
FindNextИщет каждую следующую запись в БД
FindPreviousИщет предыдущую запись в БД

23.Создайте кнопку cmdFind c надписью "Find" и впишите:

Private Sub cmdFind_Click() 
    'у пользователя запрашивается имя автора а потом происходит 
    'поиск его в БД 
    Data1.Recordset.FindFirst "Author = '" _ 
    & Trim(InputBox("Введите имя автора")) & "'" 
    'если запись не найдена появляется следующая надпись: 
    If Data1.Recordset.NoMatch Then MsgBox "Имя не найдено" 
End Sub 

24.Теперь запустите проект. Выищите какое-нибудь имя из БД и нажмите кнопку Find.

25.Введите имя и нажмите ОК.

Имя появилось! Чтобы искалось имя с конца БД слово FindFirst надо поменять на FindLast. А если Вы хотите проверить БД на наличие одного имени несколько раз надо применять слово FindNext и каждый раз вызывать поиск!

Оставить комментарий

Комментарий:
можно использовать BB-коды
Максимальная длина комментария - 4000 символов.
 

Комментарии

1.
72K
25 июля 2011 года
Vlastislav
5 / / 25.07.2011
Мне нравитсяМне не нравится
26 июля 2011, 12:10:04
Спасибо за статью, написано понятным языком и подробно
2.
27K
02 марта 2007 года
A1248I
0 / / 02.03.2007
Мне нравитсяМне не нравится
3 марта 2007, 08:00:26
Совершенно гениальная статья. Большое спасибо автору.
Реклама на сайте | Обмен ссылками | Ссылки | Экспорт (RSS) | Контакты
Добавить статью | Добавить исходник | Добавить хостинг-провайдера | Добавить сайт в каталог