бесплано рефераты

Разделы

рефераты   Главная
рефераты   Искусство и культура
рефераты   Кибернетика
рефераты   Метрология
рефераты   Микроэкономика
рефераты   Мировая экономика МЭО
рефераты   РЦБ ценные бумаги
рефераты   САПР
рефераты   ТГП
рефераты   Теория вероятностей
рефераты   ТММ
рефераты   Автомобиль и дорога
рефераты   Компьютерные сети
рефераты   Конституционное право
      зарубежныйх стран
рефераты   Конституционное право
      России
рефераты   Краткое содержание
      произведений
рефераты   Криминалистика и
      криминология
рефераты   Военное дело и
      гражданская оборона
рефераты   География и экономическая
      география
рефераты   Геология гидрология и
      геодезия
рефераты   Спорт и туризм
рефераты   Рефераты Физика
рефераты   Физкультура и спорт
рефераты   Философия
рефераты   Финансы
рефераты   Фотография
рефераты   Музыка
рефераты   Авиация и космонавтика
рефераты   Наука и техника
рефераты   Кулинария
рефераты   Культурология
рефераты   Краеведение и этнография
рефераты   Религия и мифология
рефераты   Медицина
рефераты   Сексология
рефераты   Информатика
      программирование
 
 
 

Програмирование на Visual Basic

|Single|Вещественные|От± 1.4* Ю-45 до|4 байта |

| |числа |+ 3.4*104-38 | |

|Double|Вещественные|От+ 4.94* Ю-324 |8 байтов |

| |числа |до+ 1.79* Ю-“308| |

|Varian|Произвольный|Любой из |Зависит |

|t |тип |перечисленных |от |

| | |выше |значения |

Data (Дата) - определяет дату (месяц, день, год).

Object (Объект) - ссылка на объект (OLE).

String (Строка) - последовательность ASCII-символов.

Саггепсу (Валюта) предназначен для финансовых расчетов и имеет

фиксированную точность до четвертого знака после запятой

(округляется).

Variant (Варьируемый) способен принимать любые значения (состоят из двух

частей: собственно значения и кода, указывающего исходный тип данного).

Под организацией данных понимается независимость отдельных данных (хранятся

в отдельных непоследовательных ячейках памяти) или их связанность (хранятся

в связанной последовательности ячеек памяти).

Связанными данными в Visual Basic 4 являются массивы (совокупность

связанных данных одного типа) и записи (совокупность связанных данных

разных типов).

3.2.2. Константы

Константа - данное, значение которого однозначно определяется написанием и

не может быть изменено.

Пример:

3.1415926 6.02ЕЗ (значение 60200) 123 “Visual Basic “ “Иванов “

Для хранения постоянных величин Visual Basic позволяет объявить константы,

т.е. выделить участки памяти, содержимое которых не меняется (при попытке

модификации выдается сообщение об ошибке). Объявление констант

осуществляется оператором

[Public | Private] Const имя [As type] = выражение Имя констант принято

записывать прописными буквами (правила записи имен см. ниже).

Значения ключевых слов следующие:

Public - константу можно использовать в любых процедурах и функциях;

Private - константу можно использовать только внутри модуля (см. ниже), в

котором она определена.

Пример:

Const /V= 3.1415926

Const MY_NAME = “Юра “

Тип константы можно не объявлять (устанавливается на основе значения —

Const CODE = 35 автоматически получит тип integer). Однако константа PI в

примере может быть любого из трех типов: single, double или currency. По

умолчанию принимается тип, занимающий наименьший объём памяти. Поэтому

лучше явно указывать тип специальными символами в операторах объявления

констант. Используемые символы показаны в таблице:

|Символ |Тип данных |

|объявления типа| |

|% |integer |

|& |long |

|1 |single |

|# |double |

|@ |currency |

|$ |string |

Пример:

Const ONE& = / (резервирует 4 байта)

Const ONE# = 1 (резервирует 8 байтов, хранится в виде числа

двойной точности с плавающей точкой).

В Visual Basic имеется большое число встроенных констант, значения которых

определены заранее и их можно использовать без предварительного

определения. Примерами таких констант являются:

vbOKCancel = 1 — аргумент функции MsgBox для вывода в диалоговом окне

командных кнопок ОК и Cancel;

vbYesNoCancel = 3 — аргумент функции MsgBox для вывода в диалоговом окне

командных кнопок Yes, No, Cancel;

vbOk = 1 — значение, которое возвращает MsgBox, если пользователь щелкнул

по кнопке ОК в диалоговом окне;

. vbCancel = 2 - значение, которое возвращает MsgBox, если пользователь

щелкнул по кнопке Cancel в диалоговом окне.

Полную информацию о встроенных константах можно найти в Object Browser.

Кроме того, в комплекте Visual Basic имеется файл CONSTANT.TXT, содержащий

десятки часто используемых констант. Необходимые константы могут быть

скопированы в программу. 3.2.3. Имена

Имена используются для обозначения объектов в программе (константа является

объектом программы). Правила образования имен:

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

. имя может включать только латинские буквы, цифры и знак подчеркивания

(_);

. имя может содержать не более 40 символов;

. ключевые слова или Reserved word (Зарезервированные слова) не могут

использоваться в качестве имен (список ключевых слов содержится в

справочной системе Visual Basic в разделе Reserved word).

Примеры:

Правильные имена Неправильные имена StartTime CM*PER*INCH

А2 23В

color File (ключевое слово) • VariableName BMW_360

Хорошим тоном при программировании на любом языке является осмысленный

выбор имен для объектов программы (присваивать объектам имена,

соответствующие контексту и несущие описательную нагрузку). В качестве

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

щелчком мыши по командной кнопке, запускающей программу btnStart_CUck:

первая часть имени состоит из сокращения слова кнопка (button — btn) и

слова Start, вторая часть определяет событие — Click.

3.2.4. Оператор объявления

Оператор объявления резервирует в памяти место для хранения данных

определенного типа и организации и присваивает ему имя, по которому

производится обращение к данным.

Оператор имеет вид:

Global имя [({описатель})} [As [New] тип} [, имя [([описатель])]

[As [New]w“n] ] . . .

Dim, Global, As, New — ключевые слова (Global используется для объявления

глобальных данных (см. ниже). New используется для создания нового объекта

на основе существующих объектов, например формы);

имя — имя объекта (имя переменной, массива);

тип - тип данных;

описатель — определяет организацию данных (например, массива,

см. ниже).

Пример:

Dim Name, YourName As String, N As Integer, Money As Currency,

SiirName As String* 15

(переменная SurName определена как символьная фиксированной длины в 15

символов).

При описании имен прописные и строчные буквы воспринимаются одинаково.

Однако после определения ссылки на эту переменную должны соответствовать

последней форме записи (производится автоматическое преобразование текста

программы).

Visual Basic допускает использование имен без объявления их типа (в этом

случае автоматически определяется тип, требующий для размещения минимальной

памяти), однако целесообразно и является признаком хорошего тона явно

объявлять типы используемых данных.

Из рассмотренных в предыдущей главе примеров программ для работы с формами

и управляющими элементами известно, что любая программа состоит из формы и

элементов управления, которым поставлены в соответствие процедуры. Более

сложные программы могут включать несколько форм.

Существует понятие области действия (scope) данных, определяющее

возможность доступа к тем или данным (например, к переменной) в отдельных

процедурах одной формы или в процедурах, относящихся к разным формам одной

программы.

Если оператор объявления какой-либо переменной находится внутри процедуры

обработки события, то доступ к этой переменной (возможность ее

использования) возможен только в рамках данной процедуры. Такая переменная

называется локальной (local).

Для того чтобы одна и та же переменная могла использоваться в разных

процедурах одной формы, оператор объявления переменных должен быть помещен

в раздел общих объявлений (general), доступ к которому открывается щелчком

мыши по элементу “general” раскрывающегося списка окна Object формы.

Объявленная таким образом переменная имеет статус действующей на уровне

модуля (modul-level variable) и может использоваться (доступна) в любой

процедуре данной формы. Для того чтобы одна и та же переменная могла

использоваться в процедурах разных форм одной программы она должна быть

объявлена как глобальная переменная (global variable). Используется

ключевое слово Global вместо Dim.

Пример:

Global Name, YourName As String, N As Integer, Money As Currency,

SurName As String* 75

Операторы объявления глобальных переменных помещаются в-модулях кода (code

modules, см. ниже) и эти переменные могут использоваться во всей программе.

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

В Форме 1 переменная Р объявлена в разделе общих объявлений (general) формы

и может быть использована как в Процедуре X, так и в Процедуре Z. Изменение

значения переменной в одной из процедур влечет за собой изменение и в

другой процедуре.

[pic]

Рис. 3.1

Объявленные переменные И в Процедуре Х и G в Процедуре Z Формы 1 определены

только внутри этих процедур, аналогично переменной G в Процедуре_У Формы 2.

Эти переменные определены только в рамках своих процедур. Более того, для

одноименных переменных G в Процедуре Z и в Процедуре Y выделяются разные

ячейки памяти и изменение значения переменной

G в одной из процедур не влечет изменения значения в другой процедуре.

Переменные А и В определены как глобальные для всей программы и доступны во

всех процедурах Формы 1 и Формы 2. Изменение значения переменных в одной из

процедур одной из форм влечет изменение значений в других процедурах и

формах.

Рассмотренные области действия переменных справедливы и для других

объявляемых данных (констант, пользовательских типов данных, массивов и

др.).

Как было сказано выше, описания глобальных данных помещаются .в модуль

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

отдельном файле с расширением .FRM. Программы, состоящие из нескольких форм

и соответственно из нескольких таких файлов, размещаются в файлах модулей

кода с расширением. Такие файлы создаются при выборе в меню Insert

(Вставить) команды Module (Создать модуль) или при щелчке мыши на

одноименной кнопке панели инструментов.

3.2.5. Пользовательские типы данных (записи)

Данные различных типов можно сгруппировать по какому-либо признаку в

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

такие структуры называются записями (records).

Оператор объявления пользовательского типа данных (записи) помещается в

модуль и имеет вид:

Type имя записи имя элемента записи [(описатель)} As тип

[имя элемента записи [(описатель)} As тип}

End Type

[pic] Оператор создает указанную структуру данных, но не выделяет под неё

память. Память выделяется рассмотренным оператором описания, в котором в

качестве типа указывается имя записи (имя пользовательского типа данных).

Пример:

Dim Student_l, Student_2 As Student Описаны два имени (Student_l, Student_2

), для каждого из которых определены заданные в структуре компоненты

(Familia, Name, Voyast, Birthdate, Length, Wegith) и для хранения значений

которых выделяется память соответственно заданному типу (длине и способу

представления).

Для обращения к конкретному свойству (элементу структуры) определенного

объекта используется составная запись

имя переменной.элемент структуры

Например, Student'_]. Birthdate определяет дату рождения студента

Student_7.

3.2.6. Массивы

Массив - упорядоченный набор однотипных данных, обозначенный одним именем.

Массив может строится из однотипных переменных, однородных пользовательских

типов данных (одинаковых записей), однотипных элементов пользовательских

типов данных.

Массив объявляется уже рассмотренным оператором

{Dim | Global [ Static) имя [({описатель})} [As [New] тип} [, имя

[([описатель])} [As [NewJ/гаил] ] . . . где описатель имеет следующий

синтаксис:

[нижняя граница То ]верхняя граница[,[нижняя граница То] верхняя граница] .

.

нижняя граница определяет минимальное значение индекса массива (целого

типа);

верхняя граница определяет максимальное значение индекса массива (целого

типа);

То — ключевое слово.

Количество повторений [нижняя граница То [верхняя граница определяет

размерность массива (количество индексов, используемое для определения

элементов массива). Максимальное число индексов равно 60.

Static в процедурах и функциях позволяет сохранить значения элементов

объявленного таким образом массива между вызовами этих процедур или

функций.

Пример различного способа объявления одного и того же массива:

. Dim A(8,3) As Double Dim A(6>To 8, О То 3) As Double Dim A(8, OTo 3}

As Double

Объявляется двухмерный массив (два индекса). Нижняя граница

обоих индексов равна 0 (принимается по умолчанию). Верхняя

граница первого индекса равна 8, второго — 3. Массив состоит из

36 элементов (9*4=36) одинакового типа (вещественный) и каждый

элемент занимает 8 байтов.

Границы значений индексов: от —32768 до 32767.

Примеры:

Dim A(—4 То 10} As Integer

Dim B(—99 То —5, —3 То 0) As String

Элементы массива занимают связанную последовательную область в памяти

машины. Массив А в примере занимает в памяти машины последовательность из

15 ячеек памяти, каждая из которых имеет длину 2 байта (тип Integer имеет

длину 2 байта, рис. 3.2).

[pic]

Многомерные массивы также занимают линейную последовательную область

памяти. При этом важное значение имеет способ упорядочения элементов

многомерных массивов, который отличается для различных языков

программирования.

В Visual Basic многомерные массивы упорядочиваются в памяти машины так, что

быстрее всего меняется левый индекс. Например, двумерный массив (в

прикладных математических программах матрицы представляются двумерным

массивом) А (2,3), состоящий из 12 элементов, располагается в памяти машины

следующим образом: А(0,0), А(1,0), А(2,0), А(0,1), А(1,1), А(2,1), А(0,2),

А(1,2), А(2,2), А(0,3), А(1,3), А(2,3) (если данный

массив представляет матрицу, то в памяти машины она упорядочивается по

столбцам).

Для рассмотренного пользовательского типа данных (записи) Student можно

также объявить массив оператором Dim MasStudent (25) As Student

Объявляется одномерный массив MasStudent, состоящий из 26 элементов, каждый

из которых является одной записью:

Type Student

Familia As String * 20 Name As String * 10 Voyast As Integer Birthdate As

Double Length As Integer Wegith As Integer End Type

рассмотренной выше. Записи располагаются последовательно в памяти машины и

занимают каждая 44 байта. 20 байт занимает Familia (один символ занимает 1

байт), 10 байт - Name, 2 байта -Voyast (целый тип занимает 2 байта), 8 байт

- Birthdate (вещественный двойной точности занимает 8 байт) и по 2 байта

-Length и Wegith (целый тип).

Элемент пользовательского типа данных (записи) может являться массивом.

Например, можно объявить массив записей для хранения результатов экзаменов

студентов группы. Туре Rezultat

Familia As String * 20 NameExam (4) As String * /5 RewltExam (4) As Integer

End Type Dim Sesia(25) As Reyiltat

Объявлен пользовательский тип данных Rewltat, элементами которого являются

Familia фиксированной длины 20 символов (фамилия студента не может состоять

более чем из 20 символов), массив NameExam (4) из пяти элементов (число

экзаменов в сессии не более 5) для хранения названия экзаменов (название

каждого экзамена не может состоять более чем из 15 символов), массив

RewltExam (4) из пяти элементов для хранения оценок по каждому экзамену

(целого типа). Длина записи Rewltat 105 байтов.

На базе пользовательского типа данных Requital объявлен массив Seпъ1 | |

| | | |

|Binary |Двоичные |До 1,2 Гбайт |

|OLE |OLE — объекты |До 1.2 Гбайт |

Кроме механизма Jet можно также использовать драйверы связи открытых баз

данных (ODBC — Open Database Connectivity) для доступа к другим базам

данных. Существуют также разнообразные механизмы баз данных других фирм,

которые можно использовать с Visual Basic.

Система Visual Basic позволяет хранить и использовать информацию в

реляционных системах управления базами данных (английская аббревиатура —

RDBMS).

5.2. РЕЛЯЦИОННАЯ СТРУКТУРА ДАННЫХ

В подавляющем большинстве существующие СУБД построены на основе реляционной

модели данных, которая, несмотря на свою внешнюю простоту, базируется на

прочном фундаменте масштабных теоретических исследовании, основы которых

были заложены Э. Коддом в 1969 г. Результаты этих теоретических

исследований позволяют сделать данные полными непротиворечивыми и не

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

хранился только один' раз. Специалисты в области создания и сопровождения

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

Реляционная база данных это такая база данных, которая состоит из таблиц (и

ничего иного, кроме таблиц). Ссылка из одной таблицы на другую через какое-

нибудь общее поле (common field) называется отношением (relation) ( отсюда

и название реляционная).

Рассмотрим пример реляционной базы данных состоящей из трех таблиц или

отношений, таблица поставщиков, таблица деталей и таблица поставки деталей.

Таблица поставщиков

|Номер |Фамилия |Состояние |Город |

|постав | | | |

|щика | | | |

|si |Смит |20 |Лондон |

|s2 |Джонс |10 |Париж |

|s3 |Блеик |30 |Париж |

|s4 |Кларк |20 |Лондон |

|s5 |Адаме |30 |Атенс |

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

поставщик находится только в одном городе.

Таблица деталей

|Номер |Название|Цвет |Вес |Город |

|детали | | | | |

|Pi |Гайка |Красный |12 |Лондон |

|р2 |Болт |Зеленый |17 |Париж |

|РЗ |Винт |Голубой |17 |Рим |

|р4 |Винт |Красный |14 |Лондон |

|р5 |Кулачок |Голубой |12 |Париж |

|Р5 |Заклепка|Красный |19 |Лондон |

Каждый вид детали имеет уникальный номер. Город — место хранения детали.

Предполагается, что каждый вид детали имеет только один цвет и хранится на

складе только одного города.

Таблица поставки деталей

|Номер |Номер детали |Количесшо |

|поставщика | | |

|Si |Pi |300 |

|Si |Р2 |200 |

|si |РЭ |400 |

|sl |Р4 |200 |

|si |Р5 |100 |

|sl |р6 |100 |

|s2 |Р' |300 |

|s2 |Р2 |400 |

|s3 |Р2 |200 |

|s4 |Р2 |200 |

|s4 |Р4 |300 |

|s4 |Р5 |400 |

Таблица поставки деталей служит для связи между собой двух первых таблиц.

Например, первая строка этой таблицы связывает поставщика “sl” из таблицы

поставщиков с деталью “р1” из таблицы деталей (представляет поставку детали

вида “р1” поставщиком с номером “sl” в количестве 300 деталей).

Предполагается, что в каждый момент существует только одна поставка для

заданного поставщика и заданной детали, т.е. комбинация Но-мер_поставщика,

Номер_детали является уникальной для заданной поставки относительно

множества поставок в данный момент.

Принципиальной особенностью таблиц является следующее:

. данные в таблицах имеют только явные значения, т.е. не существует

каких-либо связей или указателей, соединяющих одну таблицу с другой.

Связь, например, между поставщиком и деталью задана наличием

конкретного номера поставщика (sl) и конкретного номера детали (р1).

Такие ссылки из одной таблицы на Другую через какое-нибудь общее поле

(Common field) называется отношением;

. таблица состоит из строки заголовков столбцов и нуля или более строк

значений данных;

. строка заголовков столбцов специфицирует один или более столбцов,

определяя также тип данных для каждого из них (все значения в данном

столбце одного типа. Например, имя поставщика типа строки символов,

число деталей некоторого арифметического типа и т.п.);

. значения данных являются атомарными, т.е. в каждой ячейке таблицы

всегда только одно значение.

Строка таблицы также называется записью. Элемент записи называется полем

(наименьшая единица информации в базе данных)

Прикладная информация может по-разному задаваться таблицами (т.е количество

таблиц и их содержание могут быть различными для одной и той же прикладной

информации). Например, можно было бы вместо трех таблиц “Таблица

поставщиков” “Таблица деталей” и “Таблица поставки деталей” сделать одну

объединенную таблицу. В этом случае происходило бы дублирование информации

(для каждой детали повторялась бы информация о поставщике). Если бы

изменилась какая-либо информация по поставщику (например, состояние), то

эту информацию необходимо бы было изменить во всех записях.

Для правильной организации данных в таблицы используется понятие

нормализации. Нормализация данных — процесс исключения избыточной

информации, при которой достигается то что каждый элемент информации

запоминается только один раз. Теория и практические рекомендации по

нормализации рассматриваются в книгах по реляционным базам данных.

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

обычно называют первичными и внешними ключами. Первичный ключ однозначно

определяет запись в таблице (в таблице поставщиков таким первичным ключом

является номер поставщика) и должен быть уникальным. Внешним ключом

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

таблице поставок такими внешними ключами являются номер поставщика и номер

детали, которые используются для связи с другими таблицами). Таблицы

связываются между собой с помощью ключевых полей.

Ключевое поле может иметь содержательный смысл (например, фамилия, но в

этом случае фамилии не могут повторяться) или полем, которое служит

специальной цели обеспечения уникальности записи (например, номер

поставщика или счетчик для первичного ключа). Поле счетчика является

целочисленным полем, которое автоматически увеличивается на единицу

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

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

Приведенные таблицы являются исходными (базовыми) для задания данных и

связей между ними. Такие таблицы физически существуют в памяти ЭВМ, хотя их

вид необязательно соответствует приведенному (физическое представление

данных, т.е. то, как данные реально хранятся на носителях данных,

отличается от их логического представления в виде рассмотренных таблиц и

зависит от типа ЭВМ и носителя данных).

Кроме того, на основе базовых таблиц могут быть созданы производные от них

или представления. Например, таблица поставщиков деталей в количестве

больше 200 имеет вид:

|Номер |Номер |

|поставщика |детали |

|si |Pi |

|si |P3 |

|s2 |pi |

|s2 |?2 |

|s4 |P4 |

|s4 |?5 |

Такая таблица является производной или виртуальной таблицей, те. таблицей

которая непосредственно не существует в физической памяти, но для

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

В результате информационного запроса (query) к реляционной базе данных

также получается некоторая таблица, которая является представлением

существующих данных. Заложенные в исходных таблицах отношения позволяют

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

приведенная таблица является результатом запроса о поставщиках и деталях,

поставляемых в количестве более 200.

Для более эффективной работы с реляционной базой данных (повышение скорости

получения информации и модификации данных) используется индексирование

(аналогично рассмотренному индексированию записей файла). Индекс создается

для одного или нескольких заданных столбцов таблицы (для одной таблицы и

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

упорядочения (например, по убыванию) и автоматически поддерживается

средствами СУБД при изменении информации. Для приведенных таблиц могут

быть, например, созданы индексы по столбцу “Номер поставщика” таблицы

поставщиков, по столбцу “Номер детали” таблицы деталей, по двум столбцам

“Номер поставщика” и “Номер детали” таблицы поставки деталей.

Для работы с реляционными базами данных существует стандартный язык

запросов SQL (Structured Query Language — язык структурированных запросов).

Этот язык используется для создания исходных таблиц базы данных (создание

базы данных) формирования запросов, управления базами данных, позволяя

использовать стандартные средства для работы с различными базами данных.

Visual Basic позволяет использовать язык SQL для работы с базами данных.

5.3. ИСПОЛЬЗОВАНИЕ ЭЛЕМЕНТОВ УПРАВЛЕНИЯ Data и Grid

Элемент управления Data служит для установления связи между базой данных и

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

базы данных. Поддерживается связь с базами данных Access, FoxPro, dBase,

Paradox (список поддерживаемых связей определяется версией Visual Basic).

Один элемент управления Data всегда обеспечивает доступ только к одной

записи в данный момент (такая запись называется текущей (current)),

позволяя отображать содержимое текущей записи на форме.

Кроме стандартных свойств, элемент управления Data обладает следующими

специфическими свойствами:

. BOFAction (Beginning Of File — начало файла), EOFAction (End Of File —

конец файла) возвращает или устанавливает значение, указывающее

действие при значении BOF или EOF, равном True.

Свойство BOF равно True, если указатель текущей позиции в файле расположен

до какой-либо записи (обычно возникает при удалении первой записи).

Свойство EOF равно True, если указатель текущей позиции в файле расположен

за существующими данными. Если любое из этих свойств равно True, то текущая

запись имеет недопустимый номер. Если оба свойства равны True, то в файле

не содержится данных.

Синтаксис:

объект. BOFAction [= значение} объект. EOFAction f= значение}

BOFAction =1 — переход к первой записи, если BOF = True. EOFAction =1 —

переход к последней записи, если EOF =

True.

. Connect (Подключение) определяет тип (формат данных) используемой базы

данных (Access, FoxPro, dBase, Paradox и др.).

. Database объект “описатель базы данных” (профессиональная версия

Visual Basic)

. DatabaseName (имя базы данных) определяет имя файла базы данных или

переход.

. EditMode возвращает значение, определяющее состояние редактирования

для текущей записи.

. Exclusive определяет использование базы данных одни или несколькими

пользователями (True — использование одним пользователем. False (по

умолчанию) — несколько пользователей).

. Readonly определяет возможность редактирования ото-// бражаемого

данного в элементе управления (False (по умолчанию) — редактирование

возможно, True — невозможно).

. Recordset возвращает или устанавливает объект Recordset, определенный

свойствами элемента управления Data или существующим объектом

Recordset.

Элемент Data автоматически инициализируется при запуске приложения. Если

свойства Connect, DatabaseName, Options, RecordSource, RecordSource,

Exclusive, ReadOnly и RecordsetType установлены или, если они

устанавливаются на этапе выполнения при использовании метода Refresh,

механизм баз данных Jet пытается создавать новый объект Recordset,

основанный на этих свойствах. Этот объект Recordset доступен через свойства

элемента управление Data.

Важно: ссылаться на свойства объекта Recordset, создаваемого элементом

управления Data, можно только используя свойство Recordset самого элемента

Data. Синтаксис такого определения свойства следующий:

о^бетс/и/.свойствоА.свойствоБ определяет свойствоБ некоторого объекта,

адресуемое через свойствоА объекта!.

Объект Recordset представляет запись в основной таблице или запись, которая

является результатом выполнения запроса. Когда используются объекты доступа

к данным, то это происходит с использованием объектов Recordset. Таблица.

Recordset есть представление основной таблицы. Dynaset-тип.Recordset —

динамический набор записей. Кадр. Recordset — статическая копия множества

записей (может содержать поля из одной или более таблиц в базе данных, но

не может модифицироваться).

. RecordsetType определяет тип набора записей, который можно

использовать для доступа к данным. Существует три типа наборов

записей: таблица. Dynaset (динамическое множество) или кадр

(моментальный снимок). Соответственно свойство принимает значения 0,

1,2.

При использовании Data для доступа к базе данных по умолчанию создается

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

информацию. Динамический набор является очень гибким, но имеет ряд

ограничений при использовании (в частности не поддерживает созданные

индексы, что не позволяет динамически изменять порядок представления

записей в наборе).

При задании типа набора “Таблица” возможен доступ только к одной полной

таблице с использованием индекса для упорядочения, но обновление данных

отображается медленно.

При задании типа набора “Кадр” работа выполняется с копией данных.

Достоинством является быстрота, но требует ресурсов памяти и невозможно

обновление данных.

. RecordSource (источник данных) определяет, откуда извлечь данные. Это

может быть имя таблицы либо конкретное логическое представление данных

(запрос).

Для объекта Data при работе с базами данных существует понятие базовых

элементов управления — непосредственно связаны с единственным полем в

наборе записей и не требуют дополнительного определения, кроме имени поля,

задаваемого для некоторого свойства элемента управления. Например, для

текстового окна (TextBox) присвоение свойства Text может содержать значение

поля базы данных (тип данных: строка символов, арифметический тип, дата) и

определяется заданием свойств DataSource (указывается имя объекта Data) и

DataField (указывается имя поля таблицы, установленной свойством Data-

Source объекта Data). Окна изображений и рисунков можно использовать для

показа картинок, хранящихся в базе данных, флажок — для отображения булевых

значений.

В комплекте Visual Basic имеется база данных B1BLIO.MDB, содержащая

библиографические сведения по Visual Basic. Она состоит из трех таблиц.

Таблица Авторы (Authors) с полями идентификационный номер (Au_lD) и фамилия

автора (Authors). Таблица издательств (Pablishers) с полями

идентификационный

номер (PubID), название (Name), компания владелец (Company Name), адрес

(Address), город (City), штат (State), код (Zip), теле-tboH (Telephone).

Таблица Названия книг (Titles) содержит список опубликованных книг:

название (Title), год публикации (Year published) и ссылки на первые две

таблицы.

Используем элемент управления Data для доступа к этой базе данных. Создадим

форму (рис. 5.1) с элементом управления Data, с тремя метками и с тремя

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

B1BLIO.MDB. Свойствам объекта Data присваиваются следующие значения:

DataBaseName = C:\VB4\BIBLIO.MBD

RecordSourse = Pablishers

Connect = Access.

Для подключения базы данных (задание значения свойства DataBaseName =

C:\VB4\BIBLIO.MBD) используется специальное окно (рис. 5.2).

[pic]

Свойствам объекта Textl (текстовое окно с заголовком “Издательство”)

присваиваются значения:

DataSourse = Datal (имя элемента Data — Datal), DataField = Name (Name —

имя поля таблицы издательств). *

Рис. 5.

Свойствам объекта Text2 (текстовое окно с заголовком “Город”) присваиваются

значения: DataSourse = Datal (имя элемента Data — Datal), DataField = City

( City — имя поля таблицы издательств).

Свойствам объекта Text3 (текстовое окно с заголовком “Телефон”)

присваиваются значения: DataSourse = Datal (имя элемента Data — Datal),

DataField = Telephone (Telephone — имя поля таблицы издательств).

Созданное приложение позволяет просматривать базу данных, получая из нее

указанную информацию. Элемент управления Data обеспечивает движение по

записям (последовательное Движение к последующей записи или к предыдущей

записи при щелчке мышью по правой или левой стрелке объекта и переход “

первой или последней записи при щелчке мыши по левой или правой кнопке

окна) (рис. 5.3).

Аналогичные действия можно проделать без использования мыши, а программно.

Для этого применяются методы объекта Data.

[pic]

phl 5 2

[pic]

Такгцуж методам являются:

. Refresh — открытие и закрытие базы данных;

. MoveFirst — текущей становится первая запись из множества записей:

. MoveNext — текущей становится следующая запись из множества записей;

Рис 53

. Move Previous — текущей становится предыдущая запись из множества

записей;

. MoveLast — текущей становится последняя запись из множества записей;

. Update — редактированное поле записывается в базу данных ( этот можно

применять только для таблиц и динамических множеств);

. FindFirst найти первую запись для заданного условия поиска;

. FindNext найти следующую запись для заданного усло-„ия поиска:

. FindLast найти последнюю запись для заданного условия

поиска;

. FindPrevious найти предыдущую запись для заданного условия поиска.

Последние четыре метода требуют задания критерия поиска записи. В общем

случае критерием является строка символов, которая может включать

логические выражения. Переменной типа строки символов, являющейся

критерием, присваивается значение Следующие примеры показывают задание

критериев:

Dim Criteriy As String

Criterly = “State = ' NY ' “ ' значение поля State (Штат) таблицы должно

быть равно NY Criteriy = “Title > ‘A’ And Title < 'В' “ ' первой буквой

поля Title таблицы должна быть буква А Criteriy = “Name =” & “'” & Poisk &

“'” ' значение поля Name таблицы должно быть равно значению переменной

Poisk

Следует обратить внимание на то, что задаваемое значение в условиях берется

в апострофы “ символ — '”. В последнем примере эти апострофы специально

задаются.

При использовании методов для поиска записей используется также свойство

NoMath, применяемое для таких объектов, как таблица, динамическое

множество, кадр или Recordset. Синтаксис использования свойства следующий:

Объект. NoMath

Свойство принимает значение True (требуемая запись не найдена) или False

(требуемая запись найдена). Если поиск оказался безрезультатным, то

свойство имеет значение True и положение текущей записи (в момент

применения одного из указанных выше методов поиска) не меняется.

Как было сказано выше, ссылаться на свойства объекта Recordset,

создаваемого элементом управления Data, можно только используя свойство

Recordset самого элемента Data (синтаксис см. выше). Таким образом, при

использовании перечисленных методов вставляется свойство Recoidset элемента

Data. Например,

Datal.Recordset.MoveLast Datal.Recordset.MoveNext Datal.Recordset.FindFirst

FindCriterly

Пример программы.

Модифицируем приведенную выше форму, добавив командные кнопки и текстовую

строку (рис 5 4) Свойству Visible для элемента управления Data присвоим

значение False (т е на этапе выполнения окно Data не видимо и его нельзя

использовать для диалогового доступа к базе данных) Функции движения по

записям базы данных, действии с записями, поиска программируются

процедурами обработки событии соответствующих командных кнопок Критерии

поиска требуемой записи вводится в текстовом окне, которое активизируется

командной кнопкой “Поиск” (отрицательный результат поиска также выводится в

этом текстовом окне). В процедурах используются выше рассмотренные свойства

и методы

[pic]

Процедуры обработки событий-

Option Explicit Dim Pri, Pr2 As Boolean

Private Sub Commandl Click()

If Not Datal.Recordset.EOF Then Pr2 = True

Commandl.Enabled = True Datal.Recordset.MoveNext

If Not Pri Then Pri = True: Command2.Enabled = True Else Pr2 = False

Datal.Recordset.Move Previous Commandl.Enabled = False End If End Sub

Private Sub Command2_Ciick() If Not Datal.Recordset.BOF Then Pri - True

Command2.Enabled = True Datal.Recordset.Move Previous

If Not Pr2 Then Pr2 True: Commandl.Enabled = True Else Pri - False

Datal.Recordset.MoveNext Command2.Enabled = False End If End Sub

Private Sub Command3 Click(\

Datal.Recordset.Move First

Pr2 = True

Command2.Enabled False

Commandl.Enabled - True

Pri - False End Sub

Private Sub Command4 Click(

Datal.Recordset.MoveLast

Pri = True

Commandl.Enabled = False

Command2.Enabled = True

Pr2 - False End Sub

Private Sub Command5_ClickI

Datal.Recordset.Delete

Datal.Recordset.MoveNext End Sub Private Sub Command6_Click()

Datal.Recordset.Update End Sub

Private Sub Command7_CiicK ( i

Text4.SetFocus End Sub

Private Sub Form_Load()

Pri = True

Pr2 = True End Sub

Private Sub Text4_KeyPress(KeyAscil As Integer)

Dim FindCriteriy, Poisk As Variant

If KeyAscil = 13 Then

Poisk = Text4.Text

FindCriteriy = “Name =” & “’” & Poisk & “’”

Datal.Recordset.FindFirst FindCriteriy

If Datal.Recordset.NoMatch Then Text4.Text = “Такой записи нет”

End If

End If End Sub

Примеры работы с формой показаны на рис. 5.5 — 5.7. Обратите внимание, что

элемент Data на форме не виден. При попытке удаления записи с

использованием Delete срабатывает защита целостности базы данных (выдается

окно предупреждения на рис. 5.7). База данных включает три связанные

таблицы. Удаления записи из одной таблицы, на которую ссылается запись в

другой таблице, приводит к разрушению информации.

В рассмотренных выше примерах база данных, необходимые таблицы и поля

записей определялись на этапе разработки приложения. Однако Visual Basic

позволяет открывать при работе некоторого приложения любую существующую на

компьютере базу данных, определять состав ее таблиц и записей и выводить

для анализа всю таблицу или информацию из нее по запросу (такой способ

подключения к базе данных на этапе выполнения приложения называется

динамическим доступом).

[pic]

[pic]

[pic]

Для дальнейшего изложения рассмотрим еще одно понятие—наборы (collections)

Набор — это несколько связанных объектов, для которых определены общие

свойства. Общим для всех наборов является свойство Count, определяющее

число объектов в наборе (аналогично индексации элементов массива индексы

объектов в наборе имеют значения от о до Count — 1). Обращаться к элементам

набора можно или с использованием индекса или по именам.

Например,

Datal.Recordset.Fields(“Name”)

Data 1.Recordset.Fields(0)

В первом случае используется имя “Name” для обращения к нужному объекту

набора Fields. Во втором случае используется индекс для обращения к первому

элементу этого набора.

В приведенных примерах используется уже рассмотренный способ определения

свойств одного объекта через свойства другого (объект /.свойствоА.свойствоБ

— определяет свойствоБ некоторого объекта, адресуемое через свойствоА

объекта!).

Рассмотрим некоторые наборы, объекты набора и их свойства, которые

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

элементом управления Data, и выбора из нее информации.

Свойство Database возвращает ссылку на базу данных, определенную элементом

управления Data. Синтаксис:

Объект. Database.

Свойство Name возвращает имя объекта. Синтаксис:

Объект.^ате. Например, для используемого выше элемента управления Data с

именем Datal выражение Datal. Database. Name определит файл базы данных

C:\VB4\BIBLIO.MBD.

Свойство RecordCount возвращает число записей объекта RecordSet или

TableDef.

TableDefs определяет набор таблиц базы данных (объект TableDef является

одной присоединенной таблицей набора). Например, выражение

Datal.Database.TableDefs.Count определит число таблиц в базе данных.

Выражение Datal. Database.Table Defs(O). Name определит имя первой таблицы

в базе данных.

Fields определяет набор полей присоединенной таблицы базы данных (объект

Field является одним элементом (полем присоединенной таблицы) из набора

полей).

Выражение Datal.Database.TableDefs(0).Fields.Count определит число полей в

первой таблице базы данных.

Выражение Datal. Database. Table Defs(l).Fields(0). Name определит имя

первого поля второй таблицы присоединенной базы данных.

Выражение Datal. Recordset. RecordCount определит число записеи в текущем

множестве записей, к которому получен доступ.

Выражение Datal. Recordset. Fields.Count определит число полей множества

данных (текущее множество записей, к которому получен доступ).

Выражение Datal. Recordset. Fields(2). Name определит имя третьего поля на

множестве данных.

Выражение Datal. Recordset. Fields(2). Value определит значение третьего

поля на множестве данных.

Для отображения информации из присоединяемой на этапе выполнения базы

данных удобно использовать элемент управления Grid (Сетка). Сетка является

двумерной таблицей, позволяющей эквивалентно отображать таблицы реляционных

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

базы данных:

. Cols (Колонки) — число колонок в сетке.

. Rows (Строки) — число строк в сетке.

. GridLines — изображение линий сетки (True — линии сетки изображаются.

False — нет).

. GridLinesWidth — ширина сетки таблицы.

. Col, Row пределяет или устанавливает активную ячейку (номера колонки и

строки). Синтаксис: имя_сетки.Со\ [= номер], 11мя_сетки.Ро^/ [=

номер}. Доступны только на этапе выполнения.

. HighLight определяет подсветку выделенной ячейки сетки (True —

подсветка есть. False — нет).

. FixedCols (Фиксированные колонки) — количество фиксированных колонок

(отсчет от левого края) для отображения заголовков таблицы. Эти

колонки нельзя прокручивать и они выделяются серым фоном.

. FixedRows (Фиксированные строки) — количество фиксированных строк

(отсчет сверху вниз) для отображения заголовков. Эти строки нельзя

прокручивать и они выделяются серым фоном.

• • ScrolBars (Линейки прокрутки) — горизонтальная и вертикальная линейки

прокрутки для отображения невидимых колонок и строк. ScrolBars = 0 — нет

линеек прокрутки, 1 — горизонvbOFNPathMiistExist — возможность ввода только

существующего пути и др

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

существующего файла и существующего пути

чмя_станд _окна Flags = vbOFNFileMustExist Or \bOFNPathMustExist

Пример программы.

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

базу данных, выдает список таблиц базы данных и выводит выбранную

пользователем таблицу в сеточную форму Будет использоваться уже

рассмотренная выше база данных B1BLIO MDB Используются элементы управления

Data (имя — Datal), Gild (имя — Giidl, командная кнопка (имя — Commandl).

комбинированный список (имя — Combol) и Common Dialog (имя — CommonDialog)

Форма на этапе разработки имеет вид, показанный на рис 5 9

[pic]

Рис 5 9

Алгоритм работы приложения следующий При щелчке мыши по командной кнопке

“Подключить”, появляется стандартное диалоговое окно для выбора файла базы

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

выбранной базы данных, который выводится в комбинированное окно После

выбора элемента списка (таблица базы данных) ч

нажатия клавиши “Ввод”, содержимое таблицы выводится на сетку Линейки

прокрутки сетки позволяют просматривать все поля сетки

Текст программ'

Option Explicit

Const vbOFNPAlhMUSTEXIST - &H800&

Const vbOFNFILEMUSTEXIST &H1000&

Private Sub Commandl_Click() Combol.Clear

CommonDiaiog.DefaultExt - “MDB” CommonDialog . FileName - “”

CommonDialog.Filter =

“Базы данных MS Access(*.MDB)I*.MDB” CommonDialoci. Flags

vbOFNPATHMUSTEXIST CommonDiaiog.Action - 1

If CommonDiaiog.FileName “” Then Exit Sub OpenDataBase

CommonDialog.FileName End Sub

Public Sub OpenDataBase(ByVal DataFile As String)

Dim I As Integer

Datal.Connect - “”

Datal. Dat-abaseName = DataFile

Datal.Refresh

For I = 1 To Datal.Database.TableDefs.Count - 1

Combol.Addltem Datal.Database.TableDefs(I).Name

Next

Combol.Text = “”

End Sub

Private Sub Combol Keypress(KeyAscii As Integer)

If KeyAscii = 13 Then FillGrid Combol.Text

End If End Sub

Private Sub FillGrid^ByVal TableName As String) Dim I As Integer, CellWidth

As Integer Datal.RecordSource = TableName Gridl.Cols =

Datal.Database(TableName).Fields.Count

Gridl.Row = 0 For I =, 0 To Datal.Database(TableName).Fields.Count-1

Gridl.Col = I Gridl.Text = Datal.Database(TableName).Fields(I).Name

Gridl.ColWidth(I) = TextWidth(Gridi.Text) + 100 Next

Datdl.Refresh

Datal.Recordset.MoveLast

Gridl.Rows = Datdl.Recordset.RecordCount + 1

Datal.Recordset.Move First

Gridl.Row ^ 0

Do While Not Datdl.Recordset.EOF

Gridl.Row = Gridl.Row +• 1 For I = 0 To

Datal.Database(TableName).Fields.Count-1

Gridl.Col = I If IsNull(Datal.Recordset.Fields(I)-Value) Then

Gridl.Text = “” Else Gridl.Text - Datal.Recordset.Fields(I).Value

End If

CellWidth = TextWidth(Gridi.Text) + 100

If CellWidth > Gridi.ColWidth(I) Then

Gridi.ColWidth(I) = CellWidth

End If Next I

Datal.Recordset.MoveNext Loop End Sub

Процедура Commandl_Click обеспечивает очистку комбинированного списка и

обращение к стандартному окну “Открыть файл” с заданным расширением (*.MDB)

(рис. 5.10). После выбора файла происходит обращение к процедуре Open

DataBase, в которую передается имя выбранного файла

(CommonDialog.FileName).

Процедура OpenDataBase обеспечивает подключение к базе данных через элемент

управления Data (по умолчанию оператором Datal.Connect = “” выбирается

Формат MS Access, имя базы данных определяется передаваемым в процедуру

значением Datal. DatabaseName = DataFile) и заполнение комбинированною

списка именами таблиц (цикл). Из этого списка можно выбрать нужную таблицу

(рис. 5.11).

[pic]

Рис 5 10

После выбора таблицы, процедура обрабогки события Combo l_KeyPress вызывает

процедуру FillGrid заполнения сетки, в которую передается имя выбранной

таблицы Combol.Text.

В процедуре FillGrid инициализируется множество записей (оператор

Datal.RecordSoui-ce = TableName) и определяется количество колонок таблицы

(оператор Gridi.Cols = Datal.Database(TableName).Fields.Count), первая

строка сетки (Gridl.Row = 0) заполняется названиями колонок выбранной

таблицы (операторы

For I = 0 То Datal.Database(TableName).Fields.Coiint-l

Gridl.Col = 1

Gridl.Text = Data].Database^TableName).Fields(I).Name

Gridi.ColWidth(l) = TextWidth(Gridl.Text) + 100

Next I)

В этих операторах для задания ширины каждой колонки используется обращение

к функции TextWidth, которая возвращает длину выводимого текста.

Количество записей и соответственно количество строк сетки

определяется операторами

Datal. Refresh

Datal .Recordset.Move Last

Gridl.Rows = Datal. Recordset. RecordCount + 1 (первая строка

заполнялась названиями полей).

Возврат на первую запись и к первой строке сетки производится операторами

Datal. Recordset. MoveFirst и Gridl.Row = 0. [pic]

Рис 511

Цикл Do-Loop обеспечивает движение по записям (оператор Data I. Recordset.

MoveNext) и выполняется пока функция EOF имеет значение False (т.е. до

последней записи). На каждом шаге цикла производится переход к новой строке

(Grid I. Row = Grid 1. Row + 1), для которой выполняется цикл (Gridl.Col =

I) заполнения всех ее ячеек. Если поле таблицы базы данных не содержит

значения (проверяется функцией IsNull(Datal. Recordset. Fields(I). Value)),

то соответствующая ячейка сетки заполняется пустой строкой.

Последние операторы обеспечивают согласование ширины ячеек таблицы с

максимальной возможной длиной поля записи (операторы

CellWidth = TextWidth(Gridl.Text) + 100 • If CellWidth > Gridl.ColWidth(I)

Then

Gridl.ColWidth(I) = CellWidth).

Заполненная сетка показана на рисунке 5.12.

5.4. СОЗДАНИЕ БАЗ ДАННЫХ

Создание новой базы данных может быть выполнено программно или с помощью

специальной встроенной подсистемы Data Manager, позволяющей в диалоговом

режиме создавать и модифицировать базы данных механизма Jet. Подсистема

Data Manager запускается из раскрывающегося меню Add-Ins Главного меню

Visual Basic.

[pic]

Рис 5 12

Рассмотрим использование подсистемы Data Manager на примере создания базы

данных по товарам на складе и их поставщикам. Таблицы База данных включает

две таблицы (таблица товаров на складе, таблица поставщиков).

Таблица товаров на складе

|Номер|Номер |HilJBBUHe |Стоимость,|Количест|

|товар|поставщи|roB.tpJ |руб /hit |во на |

|а |ка | | |СКЛаДе |

|1 |2 |Магнитола |150000 |20 |

|2 |2 |Приемник |200000 |5 |

|3 |1 |Плеер |350000 |15 |

|4 |3 |Кофеварка |175000 |34 |

|5 |3 |Элсктрочаи|120000 |57 |

| | |ни к | | |

|6 |1 |CD — Плеер|750000 |8 |

Таблица поставщиков

|Номер |Название |Город |Адрес |Телефон|

|постав-|фирмы | | | |

|шика | | | | |

|1 |ЗАО |Тверь |ул. |12345 |

| |“Посредник| |Космонавт| |

| |” | |ов 12 | |

|2 |“Импульс” |Москва |Пр Мира, |2334455|

| | | |5 | |

|3 |“Старт” |Серпухов|ул |345678 |

| | | |Зеленая | |

| | | |11 | |

Таблица товаров на складе связана с таблицей поставщиков через поле “Номер

поставщика” (внешний ключ для таблицы товаров).

После щелчка мыши по пункту Data Managei раскрывающегося меню Add-Ins

Главного меню появляется окно Data Manager, в меню “Файл” нужно выбрать

пункт “New DataBase” (создание новой базы данных). Появляется окно для

создания файла базы данных (рис. 5.13). По умолчанию задано расширение

файла .mbd (файл базы данных Access).

[pic]

Рис 5 13

После задания имени файла появляется окно проектирования для задания

таблиц, полей таблиц, отношений и индексов (рис. 5.14).

Кнопка “New” используется для создания новой таблицы, “Open” — открытие

существующей таблицы для ввода данных, “Delete” — удаление таблицы,

“Design” — задание параметров полей таблицы, “Attach” — для подключения

используемой СУБД (по умолчанию — СУБД Access). “Relations” — построение

отношений между таблицами.

[pic]

Щелчок мыши по кнопке “New” открывает окно проектирования таблицы для ввода

имен полей и задания их свойств (рис. 5.15).

Рис 5 14

[pic]

Рис 515

В поле Field Name вводятся имена полей таблицы и в раскрывающемся киже меню

задается их тип (при задании типа полей “Номер товара” и “Номер поставщика”

следует выбирать Long Integei, так как эти поля будут использоваться в

качестве счетчика для первичного ключа). Стрелки “ > ” и “ < ” обеспечивают

соответственно добавление введенных имен полей или их удаление. Кнопки “Up”

и “Down” позволяют изменять последовательность полей таблицы. Аналогично

может быть введена таблица поставщиков.

Когда таблицы созданы и выбрана одна из них, активизируются кнопки Design

(проекгирование таблиц). Open (открытие таблиц для ввода или редактирования

информации). Delete (удаление таблиц) и Relations (отношения между

таблицами). Проектирование таблиц должно предшествовать заданию отношений

между таблицами и вводу данных

При щелчке по кнопке Design открывается окно редактирования (рис 5 16),

содержащее список параметров полей и командные кнопки

[pic]

Рис 5 16

Для выбранного поля таблицы (на рисунке выбрано поле “номер поставщика”)

при щелчке по кнопке “Edit” открывается окно редактирования параметров (рис

5 17). На рисунке для поля таблицы “Номер поставщика” задан параметр

“Counter” (Счетчик) Это поле является ключевым и должно иметь уникальные

значения При задании параметра “Counter”, СУБД автоматически поддерживает

уникальность этого поля, увеличивая значение счетчика при вводе новой

записи Другие параметры имеют следующий смысл DefaultValue — значение по

умолчанию, DataUpdatable — возможность изменения. Required — обязательность

ввода, AllowZeioLenght — возможность задания строки нулевой длины,

ValidationText и ValidationRule — правила корректности, Fixed или Variable

Length — фиксированной или переменной длины.

[pic]

Рис 5 17

[pic]

Кнопка “Indexes..” позволяет перейти к созданию и редактированию индексов

таблицы (рис 5 18) Для создания или

добавления нового индекса нужно щелкнуть по кнопке “Add ” открывается окно

для создания индекса (рис. 5.19).

Рис 5 18

В окне нужно задать имя индекса. Затем выбрать поля таблицы (“Fields in

tdble”), которые включаются в индекс. Выбранные поля кнопками Add(ASC) или

Add(DEC) (в зависимости от того, упорядочиваются записи по возрастанию или

убыванию) Добавляются в индексный список (“Fields in index”). Кнопка Remove

позволяет удалить поле индекса Индикаторы в окне позволяют также определить

индекс как первичный (Plimary Index) [pic]

или внешний (Foieign Index), уникальный (Unique) или кластерный

(Clustered). Соответствующий требованиям индекс сохраняется кнопкой ОК и

отображается в окне Indexes (рис. 5.18) Для удаления индекса используется

кнопка Remove

Кнопка “Keys. .” окна Table Editor позволяет перейти к созданию ключей

таблицы (рис. 5 20). В раскрывающемся списке полей таблицы выбирается поле

“Номер поставщика”, которое будет использоваться в качестве первичного

ключа. Для таблицы “Товары” первичным ключом определим поле “Номер товара”.

[pic]

Кнопка “Relations...” окна Table Editor позволяет перейти к созданию

отношений между таблицами. В окне Relations” (рис. 5.21) нужно выбрать из

раскрывающегося списка первичную таблицу (Prymary Table) и связанную

таблицу (Related Table) и установить связь между ними В рассматриваемом

примере первичной таблицей является таблица поставщиков, поле “Номер

поставщика” которой используется в качестве внешнего ключа для таблицы

“Товары”. Ключевое поле первичной таблицы (Номер поставщика) оюбражается на

поле окна Поле для связи связанной таблицы выбирается в раскрывающемся

списке (“Select Matching Fields). Связующие поля отображаются в окне.

[pic]

Вид отношения “один ко многим” (один поставщик может поставлять различные

товары) задается переключателем “Many”. Переключатель “One” определяет

отношение “один к одному”.

Флажок “Enfoice Refeiential Integrity” позволяет установить, нужно ли

обеспечивать целостность отношении (средства СУБД автоматически проверяют

целостность базы данных при модификации информации) Кнопка “Add” вводит

заданное отношение в базу данных.

Таблицы и связи между ними созданы и отображаются в списке таблиц базы

данных (рис. 5 22). При выборе таблицы становятся доступны кнопки “Open”,

“Design”, “Delete”, “Relations” Кнопка “Open” открывает выбранную таблицу

для ввода или редактирования данных (рис. 5.23). Данные приведенных выше

таблиц примера могут быть введены в базу данных.

[pic]

Рис. 5.22

[pic]

Рис. 5.23

К недостаткам подсистемы Data Manager можно отнести ограниченные

возможности по заданию отношений между таблицами. Подсистема позволяет

задать отношения только для ключевых полей “Counter” (Счетчик) и не

позволяет задать составных ключей. Базы данных сложной структуры

целесообразней создавать непосредственно в СУБВ Access, которая имеет

развитые и очень удобные средства проектирования баз данных.

Приведенная база данных может быть создана и программно. Приводится текст

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

между таблицами.

Текст программы:

Global Const DB_LANG_GENERAL =

“;LANGID-Ox0809;CP=1252;COUNTRY=0’ Global Const DB_BOOLEAN = 1 Global Const

DB_BYTE = 2 Global Const DB_INTEGER = 3 Global Const DB_LONG = 4 Global

Const DB_CURRENCY = 5 Global Const DB_SINGLE = 6 Global Const DB_DOUBLE = 7

Global Const DB_DATE = 8 Global Const DB_TEXT = 10 Global Const

.DB_LONGBINARY =11 Global Const DB_MEMO = 12

Private Sub Form_Click()

CreateNewDB End Sub

Sub CreateNewDB ()

Dim Db As Database, Dbname As String Dbname = “C:\VB\PRIMER.MDB” If

Dir(Dbname) <> “” Then Kill Dbname Set Db = CreateDatabase(Dbname,

DB_LANG_GENERAL) NewProduktTabie Db NewProviderTable Db Relations Db

MsgBox “Ваша база данных , “ & UCase(Dbname) & “, создана” End Sub

Sub NewProduktTabie(D As Database)

Dim Td As New TableDef, Fld() As New Field Dim Idx() As New Index, I As

Integer ReDim Fld(l To 5), Idx(l To 2) Td.Name = “Товары” ' Имя таблицы.

‘ Создание полей таблицы. Fid(I).Attributes = DB_AUTOINCRFIELD For I = 1 To

5 ‘ Задание свойств полей таблицы.

Fld(I).Name = Choose(I, “Номер_товара”, “Номер_поставщика”,

“Название_товара”, “Стоимость”, “Количество”)

Fid(I).Type = Choose (I, DB_LONG, DB_LONG, DB_TEXT, DB_CURRENCY, DB

INTEGER) Fld(I).Size = Choose(I, 4, 4, 30, 4, 4) Td.Fields.Append

Fid(I) Next I ‘ Создание индексов. Idx(l).Name = “PrimaryKey” Idx (1) .

Fields = “Номера/товара” • Idx(l).Primary = True

Idx(1).Unique = True • Idx(2).Name = “Name” Idx(2).Fields =

“Название_товара” For I = 1 To 2

Td.Indexes.Append Idx(I) Next I

D.TableDefs.Append Td ‘ Создание таблицы. End Sub

Sub NewProviderTable(D As Database)

Dim Td As New TableDef, Fid() As New Field

Dim Idx() As New Index, I As Integer

ReDim Fld(l To 5), Idx(l To 2)

Td.Name = “Поставщики” ' Имя таблицы. ‘ Создание полей таблицы.

For I = 1 То 5 'Задание свойств полей таблицы.

Fld(I).Name = Choosefl, “Номер_поставшика”, “Название_фирмы”, “Город”,

“Адрес”, “Телефон”)

Fld(I).Type = Choose(I, DB_LONG, DB_TEXT, DB_TEXT, DB_TEXT, DB_TEXT)

Fld(I).Size = Choose(I, 4, 30, 15, 30, 10)

Next I

Fid(l).Attributes = DB_AUTOINCRFIELD

For I = 1 To 5

Td.Fields.Append Fld(I)

Next I ‘ Создание инде^ов.

Idx(l).Name == “PrimaryKey”

Idx(1).Fields = “Номер_поставщика”

Idx(1).Primary = True

Idx(1).Unique = True

Idx(2).Name = “Fi rmNarne”

Idx(2).Fields = “Название_фирмы”

For I = 1 To 2

Td.Indexes.Append Idx(I)

Next I

D.TableDefs.Append Td ‘ Создание таблицы. End Sub

Public Sub Relations (D As Database) Dim MyField As Field, MyRelation As

Relation

Set MyRelation = D.CreateRelation(“MyRelation”) MyRelation.Table =

“Поставщики” MyRelation.ForeignTable = “Товары” Set MyField =

MyRelation.CreateField(“Номер_поставщика”) MyField.ForeignName =

“Номер_поставщика” MyRelation.Fields.Append MyField D.Relations.Append

MyRelation End Sub

Константы в программе скопированы из входящего в состав Visual Basic файла

DATACONS.TXT. Обращение к процедуре CreateNewDB создания базы данных

помещено в процедуру обработки события Form_Click, из которой производится

обращение к процедуре NewProduktTable, создающей таблицу товаров на складе,

к процедуре NewProviderTable, создающей таблицу поставщиков товаров и к

процедуре Relations, создающей отношения между таблицами. Следует обратить

внимание на удобство использования встроенной функции Choose для задания

свойств полей таблиц.

5.5. ИСПОЛЬЗОВАНИЕ ЯЗЫКА SQL ДЛЯ

СОЗДАНИЯ И РАБОТЫ С БАЗАМИ ДАННБ1Х

Язык структурированных запросов (SQL) является стандартным средством для

работы с базами данных и может использоваться как для интерактивной работы

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

Visual Basic SQL позволяет:

. создавать, модифицировать или удалять таблицы в базе данных Access;

. создавать или удалять индексы для таблиц в базе данных Access;

. вставлять, удалять или модифицировать записи таблиц;

. получать сводную информацию о данных в таблицах (число записей, суммы,

средние, минимальные, максимальные значения и др.);

. поиск данных в одной или более таблицах по запросу. Язык SQL

используется совместно с элементом управления DATA или с объектами

доступа к данным (DAO) механизма Jet. Объект Database содержит объекты

доступа к данным TableDef, определяющие таблицы, объекты Field,

определяющие поля, объекты Index, определяющие индексы и др.

В ранее рассмотренных параграфах данной главы через элемент управления Data

подключалась одна таблица (свойству Re-cordSource элемента управления Data

присваивалось значение имени таблицы). При использовании языка SQL запрос

вводится в свойство RecordSource. В случае использования элемента

управления Data, это позволяет работать с информацией из нескольких таблиц.

Следует отметить, что каждое выполнение оператора запроса изменяет набор

записеи. В связи с этим необходимо применять метод Refresh для элемента

управления Data после каждого присвоения SQL-запроса свойству RecordSource.

Рассмотрим операторы и использование языка SQL для работы с базами данных.

Для поиска информации в базе данных используется оператор SELECT. Синтаксис

оператора следующий:

SELECT список имен полей FROM список имен таблиц где SELECT, FROM —

ключевые слова;

список имен полей — список имен полей, которые выбираются из одной или

нескольких 1аблиц. Для выбора всех полей можно использовать символ “*”,

вместо перечисления имен всех полей. Если имя поля таблицы содержит пробел,

то это имя должно заключаться в квадратные скобки;

список имен таблиц — список имен таблиц, из которых производится выбор.

Имена полей и таблиц нечувствительны к регистру клавиатуры.

' Примеры:

SELECT * FROM Titles — выбор всех полей из таблицы Titles рассмотренной

выше базы данных по библиографии по Visual Basic.

SELECT Title, /Year Published/ FROM Titles — выбор полей заголовков (Title)

и года издания (Year Published) из таблицы Titles. Имя поля года издания

берется в квадратные скобки (имеет пробел).

Для поиска информации, соответствующей некоторому условию, используется

дополнение к оператору SELECT — WHERE, которое имеет следующий синтаксис:

SELECT список имен полей FROM список имен таблиц WHERE условие где условие

определяет критерии поиска информации.

В условии используются имена полей, операции сравнения (<> , >=,

<>) и специальные операции сравнения IN, LIKE, BETWEN. Эти операции могут

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

поиска информации.

Примеры:

SELECT /Year Published/, Title FROM Titles

WHERE /Year Published/ > 1991 определяет выбор названий книг, год выпуска

которых позже 1991.

SELECT I Last Name], /First Name/ FROM Employees

WHERE /Last Name/ = ‘King’ определяет выбор полей имен и фамилий из таблицы

служащих, фамилии которые совпадают с фамилией King.

Операция IN сравнивает содержимое поля со списком значений, определяющих

критерий поиска информации.

Примеры:

SELECT /Year Published/, Title FROM Titles

WHERE /Year Published/ IN (1995, 1996) определяет выбор книг,

опубликованных в 1995 и в 1996 гг.

SELECT /Last Name/, /First Name/, City FROM Employees

WHERE City In (‘Interlaken ', ‘New York’, ‘Frankfurt’) определяет выбор

служащих, живущих в городах Interlaken, New York или Frankfurt.

Операция LIKE сравнивает содержимое поля со значением образца. Для записи

образца используются строковые константы, символы шаблона и списки

диапазона символов.

Символы шаблона следующие: *, ?, #. * — соответствует цепочке символов, ? —

соответствует одному символу, # — соответствует одной цифре.

Примеры:

R* — возможные результаты поиска right, Roza.

А? — возможные результаты поиска and, any.

12345# — возможные результаты поиска 123455. 123457.

Список диапазона заключается в квадратные скобки и первый и “последний

символы диапазона отделяются дефисом (-). Диапазон задается в возрастающем

порядке.

Примеры:

SELECT /Last Name/, /First Name/ FROM Employees WHERE /Last Name/ Like ‘S*’

определяет выбор служащих, фамилии которых начинаются с буквы S. SELECT

Author FROM Authors WHERE Author LIKE fA-K/ определяет выбор авторов,

фамилии которых начинаются с букв от А .до К.

SELECT Title FROM Titles

WHERE Title LIKE “database*” AND [Year Publisher/ = 1996 определяет выбор

названий, в которых присутствует слово “database” и выпущенных в 1996 году.

Операция BETWEEN проверяет принадлежность значения поля диапазону значении

и является включающим значением (выбираются записи, содержащие поле со

значением, равным границе диапазона). Границы значений объединяются

операцией AND.

Примеры:

SELECT lOnler IDI, I Order Dale/

FROM Orders WHERE /Order Date/ Between # I-1-94” And #6-30-94# определяет

выбор документов первой половины 1994 г. С

SELECT /Last Name/, Salary FROM Employees '

WHERE [Last Name] Between ‘Lon’ And To/’ определяет выбор зарплаты

служащих, начальные буквы фамилий которых, расположенные в алфавитном

порядке, находятся в диапазоне 'Lon' и 'ТоГ.

Для определения порядка, в котором представляются результаты поиска

записей, используется дополнение ORDER BY, синтаксис которого следующий:

SELECT список имен полей FROM список имен таблиц WHERE условие ORDER BY имя

поля [DESC] [имя поля [DESC]] где имя поля — поле, по которому производится

упорядочение. Опция DESC устанавливает обратный порядок сортировки.

Упорядочение может вестись по нескольким полям (сортировка, например, по

фамилии, а затем по имени)

Пример:

SELECT Title FROM Titles WHERE Title LIKE

“*database*” AND [Year Publisher] = 1996 ORDER BY Title определяет выбор

названий книг, в которых присутствует слово “database” и выпущенных в 1996

г., и упорядочивает названия в алфавитном порядке.

При работе с несколькими таблицами, каждое из рассмотренных дополнений

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

формировании запроса для

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

связь между таблицами. Синтаксис запроса для нескольких таблиц следующий:

SELECT список имен полей FROM список имен таблиц, список связей

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

между собой. В частности для задания связи используется рассмотренное

дополнение WHERE (WHERE имя_табмщы1.1шя_поля1 = 1шя_таблицы2.имя_поля2).

Примеры:

. SELECT Tities.Title, Publishers. [Company Name} FROM Titles.

Publishers WHERE Titles. Pubid = Publishers. Pubid определяет выбор

названий книг (Title) из таблицы названий (Titles) и названий

издательств (Company Name) из таблицы издательств (Publishers).

Дополнение WHERE определяет связь между таблицами (выбирается название

книги и номер издательства из таблицы Titles, по номеру издательства в

таблице издательств Publishers находится название издательства).

SELECT Tities.Title. Authors. Author, Publishers. [Company Name]

FROM Titles, Authors. Publishers WHERE Titles.auJd = Authors. au_id AND

Tilles.pubid = Publishers. Pubid определяет выбор из всех трех таблиц

полной информации по книге (название, автор, издательство).

В целом, язык SQL имеет широкий набор средств для организации различных

запросов, о которых можно более подробно узнать из встроенной системы

помощи Visual Basic.

Пример программы.

Модернизируем приведенную выше программу для просмотра таблиц баз данных

для ввода SQL-запросов и отображения полученной информации. Добавим на

форму текстовое окно для ввода SQL-запроса (нажатием клавиши ввода запрос

вводится). Полученная информация динамически (соответственно запросу)

формируется и отображается элементом управления Grid.

Форма показана на рис. 5.24, пример ввода запроса и таблица с информацией —

на рис. 5.25. [pic]

[pic]

Текст программы:

Option Explicit

Const vbOFNPATHMUSTEXIST = &H800&

Const vbOFNFILEMUSTEXIST = S.H1000&

Private Sub Coinmandl_Click () Combol.Clear

CommonDialogI.DefaultExt = “MDB” CommonDiaiogI.FiieName = “”

CommonDialogI.Filter = “Базы данных Access(*.MDB)|*.MDB”

CommonDialogI.Flags = vbOFNPATHMUSTEXIST

CommonDialogI.Action = 1

If CommonDialogl.FileName = “” Then Exit Sub

OpenDataBase CommonDialogI.FileName End Sub

Public Sub OpenDataBase(ByVal DataFile As String)

Dim I As Integer

Datal.Connect = “”

Datal.DatabaseName = DataFiie

Datal.Refresh

For I = 0 To Datal.Database.TableDefs.Count - 1

Combo 1.Addltem Datal.Database.TableDefs(I).Name

Next

Combol.Text = “”

End Sub

Public Sub FillGrid(ByVai Zapros As String)

Dim I As Integer, CellWidth As Integer

Datal.RecordSource = Zapros

Debug.Print Zapros

Datal.Refresh

Gridl.Cols = Datal.Recordset.Fields.Count

Debug.Print Gridl.Cols

Gridl.Row •= 0 ‘

For I = 0 To Datal.Recordset.Fields.Count - 1

Gridl.Coi = I

Gridl.Text = Datal.Recordset.Fields(I).Name Gridl.ColWidth(I) =

TextWidth(Gridi.Text) + 100 . Next Datal.Refresh Datal.Recordset.MoveLast

Gridl.Rows = Datal.Recordset.RecordCount + 1 Datal.Recordset.MoveFirst

Gridl.Row = 0

Do While Not Datal.Recordset.EOF Gridl.Row = Gridl.Row + 1

For I = 0 To Datal.Recordset.Fields.Count - 1 Gridl.Coi = 1 If

IsNuil(Datal.Recordset.Fields(I).Value) Then

Gridl.Text =• “” Else

Gridl.Text = Datal.Recordset.Fields(I).Value End If

CellWidth =.TextWidth(Gridi.Text) + 100 If CellWidth > Gridi.ColWidth(I)

Then Gridl.ColWidth(I) = CeilWidth

End If Next I

Datal.Recordset.MoveNext Loop End Sub

Private Sub Textl_KeyPress(KeyAscii As Integer)

If KeyAscii = 13 Then FillGrid Textl.Text

End If End Sub

ЗАКЛЮЧЕНИЕ

Автор надеется, что прочитавший эту книгу до конца и самостоятельно

выполнивший на компьютере приведенные в ней примеры получил достаточные

знания и навыки программирования на Visual Basic, позволяющие

самостоятельно создавать программные системы.

Вы получаете в свои руки относительно простой, но очень эффективный

инструмент для создания программ, работающих в операционной системе

Windows. Эти программы могут иметь любую прикладную направленность: от

простых баз данных для личного использования на работе и дома до

профессиональных систем автоматизации производственной, торговой,

банковской, страховой и других видов деятельности.

Вы делаете первые шаги, чтобы стать специалистом в области информационных

технологий. Технологий, которые прокладывают дорогу в XXI век и в

значительной степени определят дальнейшее развитие человечества.

Желаю Вам успехов на этом сложном, но очень перспективном пути.

Страницы: 1, 2, 3, 4, 5


© 2010 САЙТ РЕФЕРАТОВ