Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:

лабы / gorev_akhajan_makakshiripov_ehffektivnaja_rabota_s_subd

.pdf
Скачиваний:
52
Добавлен:
26.04.2015
Размер:
3.17 Mб
Скачать

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

Вызвать на экран Конструктор представлений можно несколькими способами. Если вы работаете с использованием Project Manager, а это единственно правильный путь для построения сложных приложений, то вам необходимо перевести курсор на пункт списка Local Views и нажать кнопку New. После чего на экране появится диалоговое окно, в котором вам предложат создать представление с помощью Мастера или самостоятельно. Самостоятельно - значит с помощью Конструктора представлений, что ненамого сложней. Помимо этого вы можете щелкнуть по значку New в стандартной панели инструментов, и в появившемся диалоге среди предложенных типов файлов выбрать Local View.

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

Рис. 7.1. Диалоговое окно выбора таблиц или представлений

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

Ⱦɚɧɧɚɹ ɜɟɪɫɢɹ ɤɧɢɝɢ ɜɵɩɭɳɟɧɚ ɷɥɟɤɬɪɨɧɧɵɦ ɢɡɞɚɬɟɥɶɫɬɜɨɦ %RRNV VKRS Ɋɚɫɩɪɨɫɬɪɚɧɟɧɢɟ ɩɪɨɞɚɠɚ ɩɟɪɟɡɚɩɢɫɶ ɞɚɧɧɨɣ ɤɧɢɝɢ ɢɥɢ ɟɟ ɱɚɫɬɟɣ ɁȺɉɊȿɓȿɇɕ Ɉ ɜɫɟɯ ɧɚɪɭɲɟɧɢɹɯ ɩɪɨɫɶɛɚ ɫɨɨɛɳɚɬɶ ɩɨ ɚɞɪɟɫɭ piracy@books-shop.com

Рис. 7.2.

Нижняя часть Конструктора состоит из пяти страниц, заголовки которых называются Selection Criteria, Fields, Order By, Group By и Update Criteria (рис. 7.3). Здесь стоит отметить, что последней страницы нет в Конструкторе запросов. Это единственное, но очень принципиальное различие между запросом и представлением - представления могут изменять исходные таблицы при изменении данных в них.

Рис. 7.3.

На странице Selection Criteria записываются связи между таблицами и накладываются фильтры на выбираемые данные. Здесь мы фактически записываем условия предложения WHERE. Если вы еще слабо знакомы с синтаксисом SQL, то есть возможность изучать его в интерактивном режиме. В любой момент вы можете либо с помощью вызова всплывающего меню, или с помощью меню Query, или с помощью панели инструментов View Designer просмотреть SQL запрос в текстовом виде. При этом вы увидите, что как и в случае с запросами, так и с представлениями, выражение начинается с ключевого слова SELECT (рис. 7.4). Но пусть вас это не смущает, команда, создающая представления программным путем, начинается все-таки с ключевого слова CREATE SQL VIEW. Но об этом разговор чуть ниже.

www.books-shop.com

Рис. 7.4. Генерируемый в представлении код SQL запроса

Cтраница Fields служит для выбора полей из представлений и таблиц, участвующих в создании нашего представления. Можно выбрать поля другими способами, например, дважды щелкнув мышью на названии нужного вам поля или, что более эффектно, просто перетащив графический образ этого поля с образа таблицы в список Selected Output, который присутствует на страницах Fields и Selection Criteria. У визуального способа есть одно ограничение. В случае, если вам необходимо иметь в выборке не данные из поля, а, например, выражение, то вам придется воспользоваться комбинированным списком Functions/Expressions. К этому же списку вам придется обратиться в случае, если вы захотите дать колонкам свои имена с помощью опции AS.

Если вы внимательно читали параграф о SQL командах, то помните, что в команде SELECTSQL есть предложение ORDER BY, которое позволяет вам упорядочить данные по определенным полям. Для этого служит страница Order by в Конструкторах представлений и запросов.

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

Последняя страница называется Update Criteria. Именно на этой странице мы можем выбрать поля, редактирование которых в курсоре представления будет отображаться в исходных таблицах. На этой странице в списке Field Name отображаются поля из таблиц, к которым обращается запрос представления. При этом отображать можно как одновременно все поля из всех таблиц, так и только из одной таблицы, выбрав соответствующее значение в раскрывающемся списке Table (см. рис. 7.2).

Далее для каждой таблицы необходимо выбрать ключевые поля. Обратите внимание, что рядом со значком, изображающим ключ над списком Field Name, появится значок, изображающий карандаш, и вертикальная полоска ниже этого изображения. Теперь мы можем пометить поля как модифицируемые. Ключевое поле может быть одновременно и модифицируемым. Если есть необходимость отключить ключевые поля, то нажмите кнопку Reset. Когда вы хотите сделать сразу все поля модифицируемыми, нажмите кнопку Update All. При этом поля, которые вы укажете как ключевые, помечены не будут. Затем необходимо включить переключатель SendUpdates, так как только после этого исходные таблицы будут модифицироваться. Теперь с помощью кнопок выбора SQL WHERE clause includes необходимо выбрать одно из четырех значений WhereType. Оно будет определять, каким образом станет происходить поиск записи в исходной таблице:

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

Значение Key And Updatable Fields приводит к поиску записи по тем полям, которые вы пометите как модифицируемые или разрешенные для изменений и по ключевым полям.

Значение Key And Modified Fields обеспечивает поиск по ключевым и фактически измененным полям.

Значение Key and Timestamp для локальных представлений не поддерживается.

www.books-shop.com

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

Свойства WhereType и UpdateType можно установить глобально для всего Visual FoxPro, используя диалоговое окно Options на странице Remote Data. Там есть два раскрывающихся списка, объединенных общим заголовком SQL Updates, - Criteria и Method, как это показано на рис. 7.5.

Рис. 7.5. Установка параметров обновления данных

Мы уже говорили, что создать представление можно программным путем с помощью команды CREATE SQL VIEW. Свойства, с помощью которых регулируются данные в исходных таблицах, устанавливаются также программным путем с помощью функций DBSETPROP() и CURSORSETPROP(). Узнать значения установленных свойств можно с помощью функций с похожими названиями: DBGETPROP() и CURSORGETPROP(). Отличие их в том, что функции CURSORGETPROP() и CURSORSETPROP() работают с представлениями, которые в данный момент используются в какой-либо из рабочих областей. Функции DBGETPROP() и DBSETPROP() устанавливают свойства для любого представления, которое содержится в текущей базе данных. В приводимой ниже табл. 7.1 обратите внимание на то, что многие свойства можно установить только программным путем. Свойства, которые приводятся в табл. 7.1, относятся к полям представления. То есть вторым аргументом функции DBSETPROP() или функции DBGETPROP() будет "FIELD". Например:

DBSETPROP("account_and_customer.account","FIELD","comment",; "Используйте это поле для ввода номера счета")

www.books-shop.com

Обратите особое внимание, что название поля приводится вместе с названием представления

"account_and_customer.account". В противном случае Visual FoxPro не сможет найти это поле.

Таблица 7.1 Свойства полей представлений

Свойство

Тип

Описание

Caption

C

Заголовок поля. Доступно для

 

 

чтения и записи.

Comment

С

Комментарий поля. Доступно для

 

 

чтения и записи.

DataType

С

Данное свойство игнорируется

 

 

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

 

 

Доступно для чтения-записи при

 

 

работе с внешними

 

 

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

Default value

С

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

 

 

Доступно для чтения и записи.

KeyField

L

Содержит .T.,, если поле указано

 

 

как ключевое индексное

 

 

выражение. Данное свойство

 

 

можно установить визуально в

 

 

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

 

 

странице Update Criteria.

 

 

Доступно для чтения и записи.

RuleExpression

C

Правило проверки ввода уровня

 

 

поля. Доступно для чтения и

 

 

записи.

RuleText

C

Сообщение, выводимое на экран в

 

 

случае нарушении правил

 

 

проверки ввода уровня поля.

 

 

Доступно для чтения и записи.

Updatable

L

Содержит истину (.T.),, если поле

 

 

доступно для изменений. Это

 

 

свойство можно установить

 

 

визуально с помощью

 

 

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

 

 

странице Update Criteria.

 

 

Доступно для чтения и записи.

UpdateName

C

Название поля, которое

 

 

используется, когда поле

 

 

модифицируется на таблице

 

 

внешнего формата. По умолчанию

 

 

совпадает с именем поля во

 

 

внешней таблице. Доступно для

 

 

чтения и записи.

В следующей таблице приводятся некоторые свойства представления, которые можно использовать как для локальных, так и внешних представлений. Для их чтения и изменения необходимо использовать функции DBGETPROP() и DBSETPROP() со вторым аргументом VIEW. В следующем примере мы устанавливаем свойство Comment для всего представления, а затем выводим его на экран:

=DBSETPROP("account_and_customer","view", "Comment", "Предназначено для корректировки поставок по счетам")

? DBGETPROP("account_and_customer","view", "Comment")

Таблица 7.2. Свойства полей для представлений

Свойство

Тип

Описание

Comment

C

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

 

 

чтения и записи.

FetchMemo

L

Равняется .T., если данные из полей примечаний

 

 

или типа General выбираются с результатами

 

 

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

www.books-shop.com

 

 

этого поля в .F. В таком случае данные поля этого

 

 

типа будут выводиться только при прямом

 

 

обращении к ним. По умолчанию имеет значение

 

 

.T.. Доступно для чтения и записи.

MaxRecords

N

Устанавливает максимальное значение, которое

 

 

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

 

 

равно 1, то есть выбираются все записи. Если

 

 

установить это значение равным 0, то не будут

 

 

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

 

 

чтения и записи.

RuleExpression

C

Правило проверки вводимых данных уровня

 

 

записи. Доступно для чтения и записи.

RuleText

C

Сообщение, выводимое на экран при нарушении

 

 

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

 

 

для чтения и записи.

SendUpdates

L

Eсли установлено в .T., то изменения будут

 

 

посылаться в исходные таблицы. Доступно для

 

 

чтения и записи.

SourceType

N

Равно 1, если представление использует только

 

 

локальные таблицы. Равно 2, если представление

 

 

использует внешние таблицы. Доступно только

 

 

для чтения.

SQL

C

Возвращает строку запроса, который выбирает

 

 

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

 

 

чтения.

Tables

C

Разделенный пробелом список таблиц,

 

 

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

 

 

только для чтения.

UpdateType

N

Равняется 1, если старые данные в исходных

 

 

таблицах модифицируются, 2 - если данные

 

 

вначале удаляются, а затем добавляются.

 

 

Доступно для чтения и записи.

WhereType

N

Определяет, по какому принципу будет

 

 

происходить поиск записи в исходных таблицах

 

 

при модификации данных в представлении.

 

 

1 - Только по ключевым полям. Можно

 

 

использовать DB_KEY из Foxpro.h

 

 

2 - По ключевым полям и полям, разрешенным

 

 

для изменений. Можно использовать

 

 

DB_KEYANDUPDATABLE из Foxpro.h

 

 

3 - По ключевым и измененным полям.

 

 

Используйте DB_KEYANDMODIFIED из Foxpro.h

 

 

4 - Используется только для внешних

 

 

представлений. Сравнение проводится по полю

 

 

TIMESTAMP, если оно поддерживается во

 

 

внешнем представлении.

www.books-shop.com

Глава 8

Использование технологии клиент-сервер

8.1.Работа с внешними данными с помощью технологии ODBC

Команды Transact-SQL

Создание представлений Создание триггеров

8.2.Использование Visual FoxPro для разработки клиентского приложения Синхронный и асинхронный процессы Создание внешних представлений

8.3.Использование Access и Visual Basic для разработки клиентского приложения

8.4.Использование ODBC API для доступа к внешним данным

8.5.Remote Data Objects

8.6.Внешнее управление сервером с помощью SQL-DMO

До сих пор мы вели речь о приложениях, работающих на одном, локальном компьютере. Если речь шла о компьютерной сети, то БД могла располагаться на файл-сервере или нескольких файл-серверах, в качестве которого может использоваться либо специально выделенный компьютер, либо одна из объединенных в сеть наиболее мощных ПЭВМ. Функции файл-сервера заключаются в основном в хранении БД и обеспечении доступа к ним пользователей, работающих на различных компьютерах. Эти функции обеспечиваются, как правило, той же СУБД, которая работает и на компьютерах пользователей.

При небольших объемах данных эта схема вполне удовлетворяет всем современным требованиям, но с увеличением числа компьютеров в сети или ростом БД начинают возникать проблемы, связанные с резким падением производительности. Это связано с увеличением объема данных, передаваемых по сети, так как вся обработка производится на компьютере пользователя. Если пользователю требуется пара строк из таблицы объемом в сотни тысяч записей, то сначала вся таблица с файл-сервера передается на его компьютер, а затем СУБД отбирает нужные записи. В этом случае длительные перерывы в работе и число выпитых чашек кофе можно сильно сократить, перейдя на технологию клиент-сервер.

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

При технологии клиент-сервер клиентское приложение (front-end) формирует запрос к серверу БД (back-end), на котором выполняются все команды. Результаты команд посылаются затем клиенту для использования и просмотра.

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

MS SQL Server является на настоящий момент одним из наиболее мощных серверов БД.

8.1. Работа с внешними данными с помощью технологии

ODBC

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

В этом параграфе мы рассмотрим основы применения технологии ODBC для установки связи с

MS SQL Server.

www.books-shop.com

Открытый доступ к данным - Open Database Connectivity (ODBC) - это общее определение языка и набор протоколов. ODBC позволяет клиентскому приложению, написанному, например, на Access или Visual FoxPro, работать с командами и функциями, поддерживаемыми сервером.

В качестве сервера может выступать любой сервер БД, имеющий драйвер ODBC (MS SQL Server, Oracle и т. д.), или даже настольная база данных, ведь часто может возникнуть необходимость в совместной обработке данных, хранящихся в формате Paradox, приложениями, написанными и на FoxPro и на Delphi. ODBC находится как бы посредине между приложением, использующем данные, и самими данными, хранящимися в формате, которые мы не можем обработать напрямую в приложении, и используется как средство коммуникации между двумя front-end и back-end сторонами.

Для использования ODBC с целью получения данных в сети вам необходимы средства коммуникации между машиной, на которой находятся данные, и станцией, где они будут просматриваться, модифицироваться и, возможно, пополняться. Это специальная программа, которая называется Администратор ODBC на рабочей станции, и драйверы, которые могут работать как с приложением, так и с данными на сервере. Технология ODBC обеспечивает возможность хранить данные на разных серверах БД, причем не обязательно в одном формате. В теории подразумевается, что для этого не надо переписывать ни одной строчки в вашем пользовательском приложении, работающем на клиент-ской ПЭВМ. На практике так бывает не всегда, из-за различий в структуре различных уровней построения ODBC.

ODBC определяет минимальный набор SQL команд и набор функций вызова с двумя уровнями расширений. Технология ODBC включает также механизм для вызова специфических для сервера возможностей, которые не включены в стандарт ODBC. В целом, это дает возможность разработчику решать самостоятельно, какой уровень функциональности ему достаточен для доступа к серверу баз данных. Разработчик выбирает между наименьшей обеспечиваемой ODBC функциональностью или пытается использовать все возможности сервера.

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

Срасширенной функциональностью ODBC разработчик может использовать дополнительные возможности стандарта SQL и функции ODBC, чтобы расширить возможности управления внешней СУБД. Расширения ODBC включают в себя такие дополнительные возможности, как асинхронное выполнение запросов, нестандартные в среде приложения типы данных (Timestamp, Binary), прокручиваемые курсоры, SQL команды для скалярных функций, внешние объединения, хранимые процедуры и способность использовать SQL расширения, характерные для конкретного сервера БД.

Если вы используете ODBC драйверы для MS SQL Server, разработанные Microsoft в 1996 году, то вам повезло, так как их расширения предоставляют практически все возможности для полноценной работы с сервером. Если же вы работаете с сервером, отличным от MS SQL Server, или с этим сервером, но драйвер ODBC не разработан фирмой Microsoft, то у вас могут возникнуть трудности ввиду не полной поддержки функциональности сервера драйвером. Если у вас есть сомнение в функциональности драйвера, то для получения полной и содержательной информации о нем используйте функции SQLGetInfo(), SQLGetFunction() и SQLGetStmtOption(). Более подробно о них мы расскажем ниже.

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

Описание основных компонентов ODBC приведено в табл. 8.1.

www.books-shop.com

Глава 9

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

9.1.Инструментарий разработчика

9.2.Конструируем форму

Создание формы "Прием заказов" на Visual FoxPro Создание формы "Прием заказов" на Access

9.3. Разработка управляющего меню Разработка меню в Visual FoxPro Разработка меню в Access

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

При работе с современными средствами разработки приложений программист с самого начала окунается в проблемы построения интерфейса. Также и мы, обсуждая проблемы работы с данными, не могли не коснуться этих проблем. В этой главе мы как бы подведем итог обсуждаемым ранее вопросам под привычным лозунгом Microsoft "Putting It All Together!" - "Объединим все вместе!"

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

9.1. Инструментарий разработчика

Втретьей главе мы уже рассматривали визуальный инструментарий для разработки пользовательского интерфейса. Все три пакета для построения пользовательских программ (Visual FoxPro, Visual Basic и Access) имеют соответствующие средства, выполненные в виде Конструкторов и Мастеров. Если в Visual Basic и Access основным визуальным инструментарием для построения пользовательского интерфейса следует считать Конструктор формы, то в Visual FoxPro сюда следует отнести и Конструктор класса, который может эффективно использоваться для разработки многократно используемых элементов от отдельных объектов до целых форм.

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

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

врассматриваемых средствах разработки.

И все-таки даже такие мощные программные средства порой бессильны перед жесткими требованиями пользователя и неудержимым желанием программиста сделать свою программу самой совершенной в мире. В этом случае на помощь можно призвать дополнительные средства в виде богатого набора функций операционной системы - Windows API.

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

www.books-shop.com

При использовании функций Windows API программист может реализовать следующие преимущества:

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

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

Отсутствие потребности в дополнительных модулях. Альтернативой использования Windows API является приобретение дополнительных компонентов, обеспечивающих расширенную функциональность, что повышает затраты на разработку пользовательского приложения и создает дополнительные сложности при его распространении.

Вто же время мы рекомендуем использовать Windows API только в крайнем случае и при необходимости повышения скорости работы программы, так как здесь программисту приходится сталкиваться с более сложными программными конструкциями. Это, естественно, требует времени на освоение, так как те сложные задачи, которые были скрыты от программиста при использовании любимого языка программирования высокого уровня с приставкой Visual, теперь придется решать самому. При этом учтите, что Microsoft до сих не выпустила хорошего руководства или четко структурированного файла контекстной помощи по Windows API и вам придется долго блуждать среди многих сотен функций с мудреными названиями. С профессиональными версиями Visual FoxPro (только на CD-ROM) и Visual Basic поставляется файл со справочными сведениями по Windows API, но он содержит синтаксис для программирования на языке Си.

Если вы все же не раздумали использовать функции Windows API, в своей программе вам придется позаботиться о двух необходимых составляющих. Во-первых, вы должны определить путь для передачи параметров в вызываемую функцию. Во-вторых - определить механизм для получения значения, возвращаемого функцией. Эти задачи выполняет команда DECLARE.

ВVisual Basic она имеет следующий синтаксис:

[Public | Private] Declare Function FunctionName Lib "LibraryName" [Alias " AliasName" ] [([ParamList])][As ParamType]

В Visual FoxPro при том же составе параметров синтаксис команды выглядит чуть иначе:

DECLARE [cFunctionType] FunctionName IN LibraryName [AS AliasName] [cParamType1 [@] ParamName1,cParamType2 [@] ParamName2, ...]

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

Сведения о функции определяются ее именем FunctionName, заданном в библиотеке DLL. Имя функции следует указывать с соблюдением регистра! Если функция возвращает какое-либо значение, перед ее именем следует указать тип возвращаемого значения cFunctionType. Вероятно, здесь уместно напомнить, что в Visual Basic объявление Public используется для обеспечения доступа к функции из всех процедур, раположенных во всех модулях. Объявление Private обеспечивает доступ к функции только внутри данного модуля.

Имя библиотеки DLL Windows LibraryName, содержащей требуемую функцию. Если вы хотите использовать функцию, входящую в API Windows, то здесь достаточно написать WIN32API, что автоматически обеспечит поиск функции в одном из следующих файлов: KERNEL32.DLL, GDI32.DLL, USER32.DLL, MPR.DLL или ADVAPI32. DLL.

Псевдоним имени функции для использования в Visual FoxPro или в Visual Basic. Его удобно использовать для сокращения слишком длинного названия функции или при угрозе совпадения имени функции с зарезервированным словом.

Список передаваемых параметров включает обозначение типа и имени параметров, передаваемых из приложения в функцию DLL Windows. Знак @ после типа параметра показывает, что он будет передаваться по ссылке, а не по значению. Имя параметра никак не используется ни приложением, ни функцией DLL и может применяться в команде только в информационных целях. Если функция DLL требует в качестве аргумента

www.books-shop.com

Соседние файлы в папке лабы