Поиск

Полнотекстовый поиск:
Где искать:
везде
только в названии
только в тексте
Выводить:
описание
слова в тексте
только заголовок

Рекомендуем ознакомиться

'Семинар'
Физиология Петербурга, составленная из трудов русских литераторов, под редакциею Н. Некрасова. СПб: Изд. книгопродавца А. Иванова, 1845. Ч.1. 304 с.;...полностью>>
'Методические указания'
Методика изобразительного искусства как одна из педагогических дисциплин. Ее объект, предмет, задачи и методы преподавания. Методологические основы, ...полностью>>
'Документ'
Подростковый возраст очень важен, поскольку новообразованием именно этого периода является личностное самоопределение – умение подростка сделать выбо...полностью>>
'Методические рекомендации'
В процессе самостоятельной работы студент (слушатель), изучив вопросы Уголовного права, выполняют курсовую работу, которая способствует закреплению и...полностью>>

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

Главная > Документ
Сохрани ссылку в одной из сетей:

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

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

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

1.Создайте стандартный проект.
2.Кликните на ToolBox'e на кнопку Data и натяните на форму так, чтобы полоска была не очень широкой и в самом низу формы.
3.Теперь создайте на форме четыре кнопки и назовите их (по порядку создания): cmdAdd, cmdDelete, cmdUpdate, cmdExit. Свойствам Caption дайте эти же имена, только без "cmd".
4.Создайте на форме три текстовых поля одинаковой длины.
5.Теперь надо связать объект Data с какой-нибудь базой данных. С какой? С той которая есть у всех владелцев VBasic'a - biblio.mdb! Активируйте объект Data и в свойствах, в DatabaseName выберите этот файл. Теперь там же, но в поле RecordSource надо выбрать раздел "Authors". Этим мы выберем только нужную часть базы данных.
6.Выделите первое текстовое поле и в свойствах, в DataSource выберите единственную в списке, созданную нами базу данных Data1, т.е. тем самым мы связываем это текстовое поле с объектом Data1. А в поле свойств DataField выберите "Au_ID". Теперь задача этого поля отображать идентификационный номер каждого автора! То же самое проделайте со следующими двумя другими полями, но в DataField вместо "Au_ID" выберите "Author" и "Year Born".

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

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

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

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

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

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

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

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

Private Sub cmdExit_Click()
    End
End Sub

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

10.Запустите проект. Нажмите на правую кнопку >. Содержание полей сменилось! Теперь нажмите на правую кнопку >|. В полях появились самые последние записи! То же самое будет происходить при нажатии на левые кнопки |< и <. Но как Вы, наверное, заметили поле, содержащие год рождения, всегда пустое!
11.Теперь нажмите кнопку "Add".
12.Первое поле НЕ испраляйте, во второе ввидите, например, ваше имя, а в третье год рождения.
13.Теперь сохраните эту запись, нажав кнопку "Update".
14.Знайте, ваша запись теперь сохранена на самом последнем месте! Можете снова "прогуляться" по записям и вернутся наконец с помощью правой кнопки >|. Ваша запись на месте.
15.Теперь нажмите на кнопку Delete... запись исчезла! НО! В этом случае мы НЕ можем удалять записи сделанные не нами.

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

16.создайте на форме ещё две кнопки с именами cmdMBM и cmdSMB со следующими надписями: Make the Bookmark и Show the Bookmark.
17.Теперь в разделе формы General Declarations объявите переменную, которая будет содержать идентификатор актуальной записи:

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

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

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

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

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

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

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

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

Метод

Пояснение

FindFirst

Ищет первую запись в БД

FindLast

Ищет последнюю запись в БД

FindNext

Ищет каждую следующую запись в БД

FindPrevious

Ищет предыдущую запись в БД

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

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

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

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

Эффективная работа с БД в VB 6.0

В статье рассматриваются способы повышения эффективности при разработке клиент-серверных СУБД-приложений в среде VisualBasic 6.0. Наиболее подробно освещены следующие аспекты проблемы:

  • Эффективное использование стандартного для VB программного интерфейса доступа к данным (ADO);

  • Повышение эффективности процесса разработки СУБД-приложений с использованием стандартных средств, а также продуктов третьих фирм.

На кого рассчитана статья

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

Описание примеров

В качестве демонстрационного примера мы возьмем серверную часть гипотетической онлайновой системы обработки транзакций со счетами в реальном времени (назовем ее <CountDown>). Предположим, что поток транзакций достаточно велик, и ключевые таблицы базы данных содержат миллионы записей. Работу системы контролируют операторы, которым требуется немедленная статистическая обработка данных. В статье приведен необходимый минимум исходных текстов; подробные описания стандартных свойств и методов ищите в MSDN.

Необходимый инструментарий

Чтобы испытать рассматриваемые приемы на практике, потребуется Microsoft Visual Basic 6.0 с установленным SP5, а также Microsoft SQL Server 2000 (там, где речь идет о серверной части).

Программный интерфейс доступа к данным

Краткая история развития

Самый естественный способ доступа к данным в VB - COM-объекты. Изначально Microsoft предлагала для VB два вида технологий доступа к данным:

  • ориентированные на ядро JET (библиотека DAO, Data Access Objects);

  • ориентированные на источники данных ODBC (библиотека RDO, Remote Data objects).

Первая категория вообще не имеет отношения к клиент-серверной архитектуре и рассматривать ее мы не будем. Что касается RDO, то тут были проблемы, связанные как с устаревающим интерфейсом ODBC, так и с реализацией самой библиотеки RDO, как надстройки над ODBC.
Проблемы сняло появление библиотеки ADO (ActiveX Data Objects), основанной на новой универсальной технологии доступа к данным OLE DB. Эта библиотека обладает множеством новых возможностей (таких как асинхронная работа, поддержка иерархических наборов записей и пр.) и практически лишена проблем своих предшественниц. оследняя версия - ADO 2.6, в которой добавлена поддержка XML.

Библиотека ADO

Архитектура библиотеки, назначение объектов
Основное назначение библиотеки ADO - операции с DML (Data Manipulation Language, язык обработки данных). Это определяет архитектуру библиотеки, ориентированную на получение наборов данных и их последующую обработку. Библиотека содержит следующие основные объекты:

  • Connection - соединение с базой даннных;

  • Command - команда DML;

  • Recordset - набор записей;

  • Stream - поток двоичных или текстовых данных;

  • Record - запись.

Рис.1. Объектная модель ADO

Эти объекты предоставляют исчерпывающие возможности для манипуляций с данными; более того, библиотека позволяет выполнять одно и то же действие множеством различных способов, которые могут значительно отличаться по эффективности. Ниже приведены некоторые рекомендации, которые оптимизировать некоторые типичные операции.

Соединения (ADODB.Connection)
Любое действие с данными производится в контексте какого-либо активного соединения. Изучение примеров в MSDN может навести на мысль, что для каждого действия необходимо создать соединение - примерно так:

Sub DoSimpleAction(strActionSQL As

String)
Dim cn As New ADODB.Connection 
'

одключаемся к SQL-серверу
cn.Open

"Provider=SQLOLEDB.1;Persist Security Info=False;Data

Source=SomeSQLServer"
' Выполняем запрос
cn.Execute

strActionSQL 
'Отключение
cn.Close
End Sub

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

Sub DoSimpleAction(cn as

ADODB.Connection, strActionSQL as String)
' Выполняем

запрос
cn.Execute strActionSQL
End Sub

Добавим, что в этом случае желательно:

  • помещать объявление переменной в стандартный модуль, поскольку данные класса копируются, а это потенциальный источник <висячих> ссылок и возникновения таинственных <фантомных> соединений;

  • контролировать корректность соединения, поскольку оно могло прерваться в процессе работы. Для этого можно использовать свойство State и событие Disconnect объекта Connection.

Команды (mand)

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

  • Таблица (adCmdTable) - выбирает все записи из таблицы или представления;

  • Хранимая процедура (adCmdStoredProc) - вызов хранимой процедуры, которая возвращает данные;

  • Текст (adCmdText) - произвольный SQL-запрос, возвращающий данные;

  • Файл (adCmdFile) - получение данных из файла;

  • Неуказанный (adCmdUnspecified).

Общие рекомендации по использованию команд таковы: 
Не используйте команд типа <Текст> или <Таблица>. Вместо этого лучше определить для каждой операции с данными хранимую процедуру. Выгоды следующие:

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

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

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

Наборы записей (ADODB.Recordset)
Команды возвращают данные в виде наборов записей. Наборы бывают:

  • Динамические (adOpenDynamic) - видны все изменения, вносимые в данные другими пользователями и доступны все операции, поддерживаемые провайдером данных;

  • Ключевые (adOpenKeyset) - аналогичен динамическому, но не видны записи, добавляемые другими пользователями;

  • Статические (adOpenStatic) - <снимок> данных; изменения, вносимые другими пользователями не видны;

  • Однонаправленные (adOpenForwardOnly) - аналогично статическому, но возможна только прокрутка вперед.

Наборы записей также различаются типом блокировки (оптимистическая, пессимистическая, пакетная, только для чтения) и расположением курсора (клиентский или серверный).
Очевидно, стоит использовать минимальный подходящий набор возможностей (так, для отчета достаточно статического набора записей, если вам нужен однократный проход данных - используйте однонаправленный набор и т.д). Кроме того - обратите внимание на следующие возможности ADO:

Пакетное обновление (при поддержке провайдером) - дает возможность локально внести изменения в несколько записей набора, и потом передать их на сервер все вместе, <пакетом>. Для этого - вместо метода Update используйте метод UpdateBatch, установив при этом пакетный тип блокировки (adLockBatchOptimistic). Это снижает нагрузку на канал передачи данных, и уменьшает риск сбоя на ненадежном канале.

Отсоединенные наборы записей. Получив набор записей с клиентским курсором, можно разорвать соединение с базой данных, освобождая занятые им ресурсы. При этом набор записей остается доступным, и соединение в любой момент можно восстановить для обновления набора или сохранения внесенных зменений. Делается это следующим образом:

Function

GetDisconnectedRecordset(strSQL As String) As

ADODB.Recordset
Dim cn As New ADODB.Connection
Dim

rstRes As New ADODB.Recordset 
' Подключаемся к

SQL-серверу
cn.Open "Provider=SQLOLEDB.1;Persist Security

Info=False;Data Source=SomeSQLServer"
' Открываем набор

записей
rstRes.CursorLocation = adUseClient
rstRes.Open

strQSL, cn, adOpenDynamic,

adLockOptimistic 
'Отключение
Set

rstRes.ActiveConnection = Nothing
cn.Close 
Set

GetDisconnectedRecordset = rstRes
End Function

Взаимодействие с ODBC

Среди провайдеров данных для OLE DB имеется провайдер для драйверов ODBC (Microsoft OLE DB Provider for ODBC drivers), позволяющий подключаться к любым источникам данных ODBC (рис. 2). Следующий совет может показаться тривиальным, но все-таки: не используйте провайдер данных для ODBC для доступа к СУБД, если для нее существует <родной> провайдер данных. Как любой посредник, ODBC утяжеляет каждое обращение к данным; кроме того, потребуется программно создать сточник данных и следить за его корректностью. Без всего этого можно обойтись, используя с ADO <родной> для спользуемой СУБД провайдер данных. Помните, что основное назначение провайдера для драйверов ODBC - обеспечить доступ к тем СУБД, для которых еще не существует OLE DB провайдера.

Рис. 2. Выбор OLE DB провайдера для создания подключения к СУБД

Применение расширений ADO для работы со схемой данных - ADOX 
Библиотека ADO не содержит средств для работы со схемой данных. Для анализа или изменения схемы данных лучше всего воспользоваться библиотекой расширений ADO - ADOX (ActiveX Data Objects Extensions for Data Definition Language). Она содержит такие основные объекты как:

  • Catalog - база данных;

  • Table - реляционная таблица;

  • View - представление;

  • Column - столбец;

  • Procedure - хранимая процедура;

  • Index - индекс;

  • Key - первичный, внешний, или альтернативный ключ таблицы;

  • User - пользователь;

  • Group - группа.

Рис. 3. Объектная модель ADOX

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

Оптимизация процесса разработки

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

Применение DataEnvironment
DataEnvironment - стандартный ActiveX-дизайнер, входящий в состав VB. При правильном спользовании он позволяет радикально упростить процесс создания СУБД-приложения, однако многие VB-программисты, даже меющие опыт работы с базами данных, не вполне представляют себе его возможности. Для начала - добавим его к проекту (контекстное меню проекта в окне Project Explorer, см. рис. 4).


Рис. 4. Добавление DataEnvironment к проекту

В папке Designers проекта появится элемент с названием DataEnvironment1 (которое можно впоследствии зменить), а в программе - одноименный глобальный объект. режде, чем мы воспользуемся новым элементом - нужно создать все необходимые для работы приложения соединения. Теперь рассмотрим некоторые способы его применения:

Используйте конструктор DataEnvironment для создания команд. Если вы прислушались к совету собрать все операции с данными в хранимых процедурах - у вас может возникнуть вопрос: большое приложение имеет десятки и сотни подобных команд; неужели придется вручную описывать их все на VB? Тут пригодится DataEnvironment. Чтобы создать команду для вызова хранимой процедуры - просто перетащите процедуру мышью з окна Data View в окно конструктора DataEnvironment. Для каждой созданной подобным образом команды создается метод объекта DataEnvironment, аргументы которого соответствуют параметрам хранимой процедуры. Поясним на примере: если вы объявили процедеру, как:
CREATE PROC SomeProcWithManyParams
@param1 int,
@param2 varchar(255),
@param3 float
AS
.....
END

и перетащили ее как сказано выше - у объекта DataEnvironment автоматически появляется метод:
SomeProcWithManyParams(param1 As Long, param2 As String, param3 as Double)

Далее для выполнения команды с необходимыми значениями параметров можно (и нужно) пользоваться именно этим методом. Кстати, подобные методы также создаются для команд типа <запрос SQL>, однако в этом случае их аргументы, соответствующие параметрам запроса, придется доопределить вручную.

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


Рис. 5. Набор команд, созданный в конструкторе DataEnvironment

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

Используйте окно кода DataEnvironment для обработки событий, возникающих при работе с данными. Каждая команда, созданная в DataEnvironment является экземпляром класса Command; соответственно обработчики всех событий этого класса можно писать в окне кода DataEnvironment. Кроме этого, каждая команда, возвращающая набор данных, порождает дополнительный объект класса Recordset, имя которого получается добавлением префикса к имени команды. Эти объекты плюс экземпляр класса Connection, который соответствует соединению с базой данных, дают нам полный контроль над событиями, связанными с получением и изменением данных, а также над навигацией по ним. А значит - всю логику работы клиентской части приложения с данными мы можем описать именно здесь, в одном месте программы, облегчая ее понимание и поиск ошибок. Например, здесь можно связать событие перемещения по записям родительского набора записей (master) c обновлением дочернего набора записей (detail). Этот механизм будет автоматически срабатывать в любом участке программы, повлекшим навигацию, что избавляет нас от дублирования кода, которое могло бы возникнуть, свяжи мы подобную логику, например, с визуальными элементами управления.

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

' Обновляем набор

записей
deMain.rsAccounts.Requery
' Необходимо привязать

грид заново для отображения новых данных
With

grdAccounts
.DataMember = "Accounts"
Set .DataSource =

deMain
End With 

Применение CASE-средств (Visual Modeler, Rational Rose)
Разработку сложных приложений с развитой логикой и богатой объектной моделью на VB может существенно упростить и ускорить применение объектно-ориентированных CASE-средств. Конкретные преимущества такие:

  • Автоматизация процесса проектирования (создания объектных моделей);

  • Автоматическая генерация заготовок исходного кода по объектной модели;

  • Автоматический реинжиниринг кода (создание объектной модели по коду);

  • Автоматизация процесса создания документации.

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

 

Visual Modeler

Rational Rose 

Моделирование

3

5

Генерация кода 

4

5

Реинжиниринг

3

5

Документирование

2

5

Применение профайлеров (SQL-Profiler, Rational Quantify)
Создание эффективных приложений невозможно без поиска и анализа <узких мест> в коде. Анализ УБД-приложений имеет свою специфику: как правило, время выполнения разделено между программой и СУБД. Допустим, тестирование выявило в системе проблему - недостаточную производительность при большом числе клиентов. Где искать <узкое место> - в коде на VB или в хранимых процедурах? Решить проблему помогут специальные средства, предназначенные для локализации проблем производительности - профайлеры.

Rational Quantify. Этот инструмент позволяет получить детальную информацию о работе VB-приложения. В процессе контрольного выполнения собирается статистика о числе вызовов, среднем и суммарном времени выполнения каждой процедуры и даже строки программы. Если окажется, что производительность тормозят определенные хранимые процедуры - надо оптимизировать их. Если же относительная доля временных затрат на подобные вызовы невелика, дальнейший анализ статистики, собранной Rational Quantify подскажет, где искать <узкое место> в VB-коде.

SQL-Profiler. Это средство позволяет анализировать процесс взаимодействия любого приложения с MS SQL Server. Допустим, вы работаете с чужой программой, и у вас есть подозрение, что она работает с СУБД неоптимально, однако непонятны причины и условия, в которых это происходит. В этом случае пригодится SQL-profiler. Он позволяет получить подробную информацию о каждом обращении приложения к СУБД, вплоть до трассировки выполнения хранимых процедур. Если где-то делается неэффективный запрос, то он будет виден в протоколе работы как на ладони, причем в контексте предыдущих последующих вызовов, что в большинстве случаев позволяет обнаружить причину <торможения> программы.



Скачать документ

Похожие документы:

  1. Работа с базами данных

    Документ
    База данных — это организованная структура, предназначенная для хранения информации. Внимательный читатель, знающий из первой главы этого пособия о том, что данные и информация — понятия взаимосвязанные, но не тождественные, должен
  2. Задачи: Изучить среду Visual Basic; Подобрать задачи исследовательского характера для визуализации экспериментального процесса; Разработать программы и исследовать информационные процессы

    Исследовательская работа
    Visual Basic; (VB) - это среда разработки программ, которая позво­ляет быстро и легко создавать приложения (прикладные программы) для Windows. В нее включено все, что необходимо для создания, модифика­ции, тестирования, корректирования
  3. «Обработка баз данных при помощи Microsoft Access»

    Документ
    Когда необходимо хранить и использовать большие объемы данных, необходим инструмент для простой и быстрой обработки информации. В семействе Microsoft Office таким инструментом является MS Access.
  4. Базы данных (2)

    Документ
    В основе решения многих задач лежит обработка информации. Для облегчения обработки информации создаются информационные системы (ИС). Автоматизированными называют ИС, в которых применяют технические средства, в частности ЭВМ.
  5. Visual basic for applications (vba)

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

Другие похожие документы..