- •230100 Информатика и вычислительная техника
- •Введение
- •1.Функции
- •1.1. Создание пользовательских функций. Передача аргументов
- •1.2. Глобальные и локальные переменные
- •2.Процедуры
- •2.1. Пользовательские процедуры
- •2.2. Упреждающее объявление процедур и функций (forward)
- •3.Концепция типа данных
- •3.1. Абстракции в обработке информации
- •3.2. Понятие типа данных
- •3.3. Иерархия типов данных
- •3.4. Стандартные типы данных
- •3.5. Тип данных Boolean
- •3.6. Тип данных char
- •3.7. Ограниченные типы
- •4.Множества. Массивы
- •4.1. Операции над множествами
- •4.2. Массивы
- •4.3. Утверждения о массивах
- •5.Индуктивные функции на последовательностях (файлах, массивах)
- •5.1. Схема Горнера
- •5.2. Индуктивные функции
- •6.Записи
- •6.1. Представление сложных типов данных в памяти
- •6.2. Упаковка элементов сложных типов данных
- •6.3. Представление записей в памяти
- •7.Процедуры и функции
- •7.1. Создание пользовательских функций. Передача аргументов
- •7.2. Процедуры
- •7.3. Передача параметров по ссылке и значению
- •8.Основы объектно-ориентированного подхода
- •8.1. Основные положения объектно-ориентированного подхода
- •9.Конструкторы и деструкторы. Инкапсуляция
- •9.1. Хранение объектов в памяти. Доступ к свойствам из методов
- •9.2. Принцип инкапсуляции
- •9.3. Поля и свойства
- •10.Наследование и полиморфизм
- •10.1. Принцип полиморфизма
- •10.2. Виртуальные методы
- •10.3. Пример описания объекта
- •10.4. Параметры-процедуры
- •11.Основы программирования графики
- •11.1. Основные понятия компьютерной графики
- •11.2. Получение сведений о режимах экрана. Эффекты прозрачности
- •11.3. Графические построения
- •11.4. Построение графиков функций
- •11.5. Использование компонента tChart
- •11.6. Построение геометрических фигур
- •11.7. Обновление изображения
- •12.Построение динамических изображений
- •12.1. Анимация на основе операции xor
- •12.2. Буферизация фона
- •12.3. Работа с таймером
- •13.Динамические структуры данных
- •13.1. Размещение динамических переменных в памяти
- •13.2. Захват и освобождение динамической памяти
- •13.3. Нетипизированные указатели
- •14.Линейные списки: основные виды и способы реализации
- •14.1. Линейный список как абстрактный тип данных
- •14.2. Операции с динамическими массивами
- •14.3. Сортировка динамических массивов
- •14.4. Деревья
- •14.5. Потоки в памяти
- •15.Сортировка и поиск
- •15.1. Алгоритмы поиска
- •15.1.1Линейный поиск
- •15.1.2Двоичный поиск
- •15.1.3Поиск текстовых строк
- •15.2. Сортировка данных
- •15.2.1Сортировка массивов
- •16.Сортировка файлов. Рекурсия
- •16.1. Рекурсивные определения и алгоритмы
- •16.2. Программирование рекурсивных алгоритмов
- •16.3. Сортировка файлов
- •17.Файлы
- •17.1. Буферизация
- •17.2. Работа с текстовыми файлами
- •17.3. Работа с двоичными файлами данных
- •17.4. Нетипизированные файлы
- •17.5. Файловые потоки
- •18.Работа с файловой системой
- •18.1. Стандартные файловые диалоги
- •18.2. Получение сведений о дисках
- •18.3. Получение сведений о файлах
- •18.4. Сканирование дисков и директорий
- •19.Обработка исключительных ситуаций
- •19.1. Векторы прерываний
- •19.1.1Хранение данных в стеке
- •19.2. Контроль ввода-вывода
- •19.3. Обработка исключительных ситуаций в Delphi
- •20.Отладка программ
- •20.1. Интегрированная среда программирования
- •20.2. Инструменты отладки программ
- •20.3. Типичные ошибки в программировании
- •21.Принципы построения трансляторов
- •21.1. Синтаксис и семантика языков программирования
- •21.2. Структура языков программирования
- •21.3. Структура и организация работы транслятора
- •22.Параллельные процессы
- •22.1. Создание многопоточных приложений
- •22.2. Управление скоростью работы потоков
- •23.Модульные программы
- •23.1. Создание dll-библиотеки на Delphi
- •23.2. Вызов dll
- •23.2.1Статическое связывание
- •23.2.2Динамическое связывание
- •23.3. Отладка проектов с dll
- •23.4. Хранение форм в dll-библиотеках
- •24.Обмен данными между приложениями
- •24.1. Работа с буфером обмена
- •24.2. Основы ole-технологии
- •25.События и сообщения
- •25.1. Отправка и получение сообщений
- •25.2. Предотвращение повторного запуска программы
- •26.1. Основы com-технологии
- •26.2. Вывод отчета при помощи Microsoft Word
- •26.2.1Проверка наличия сом-сервера на компьютере
- •Общее правило: при работе с любым сом-сервером запретите пользователю им пользоваться, пока с сом-сервером работает ваша программа.
- •26.3. Подключение к сом-серверу Word из Delphi
- •26.4. Управление форматированием документа
- •26.5. Работа с таблицами
- •26.6. Запуск Word из внешней программы
- •26.7. Работа с AutoCad по com-технологии
- •27.Принципы организации реляционных баз данных
- •27.1. Основные сведения о базах данных
- •27.2. Проектирование структуры базы данных
- •27.3. Нормализация структур баз данных
- •28.Работа с локальными бд
- •28.1. Драйвер баз данных bde
- •28.2. Создание баз данных
- •29.Программная обработка локальных бд
- •29.1. Редактирование локальных бд
- •29.2. Вывод бд на экран
- •29.3. Цветовое выделение строк бд
- •30.Работа с распределенными бд
- •30.1. Основы языка sql
- •30.2. Понятие алиаса
- •30.4. Подключение к sql-серверу
- •31.Программная обработка данных в архитектуре "клиент – сервер"
- •31.1. Программный доступ к полям бд
- •31.2. Фильтрация и сортировка данных
- •32.Работа с нормализованными бд
- •32.1. Связывание таблиц
- •32.2. Вычисляемые поля
- •33.Субд Interbase
- •33.1. Работа с сервером Local InterBase
- •33.2. Утилита InterBase Server Manager
- •34.Работа с языком xml
- •34.1. Структура xml-документа
- •34.2. Использование xml в среде Delphi
- •34.3. Концепция dom - объектная модель документа
- •34.4. Использование xml
- •35.Основы программирования для Интернет
- •35.1. Работа с протоколом ftp
- •35.2. Передача файлов по ftp
- •Библиографический список
- •Приложение. Зарезервированные слова sql
- •Предметный указатель
30.1. Основы языка sql
Итак, для доступа к БД используются выражения специального языка запросов SQL (Structured Query Language). Язык SQL включает несколько операторов для работы с данными, но пока нам достаточно знать всего один, главный – SELECT. Вот его общий вид:
SELECT {поля} FROM {имя файла БД}
[WHERE {условие}] [ORDER BY {поля}]
Необязательные части заключены в квадратные скобки, вместо фигурных скобок подставляются конкретные значения.
Чтобы запросить всю БД из файла с именем DVD.db со всеми полями, следует выполнить оператор SQL
SELECT * FROM DVD
Здесь символ "*" означает "все поля базы". Имя файла необязательно брать в кавычки. Это приходится делать, если оно совпадает с одним из ключевых слов SQL (см. приложение).
Чтобы запросить не всю базу, а некоторую выборку, т.е. только те записи, которые отвечают какому-то условию, используется конструкция WHERE. Например, если мы хотим увидеть только диски с фильмами, вышедшими в 2003 году, следует задать условие YEARF = 2003 (вспомним, что YEARF – это имя поля в нашей базе):
SELECT * FROM DVD WHERE YEARF=2003
Наконец, базу можно отсортировать (упорядочить) по какому-то полю. Например, выведем названия дисков в алфавитном порядке:
SELECT * FROM DVD ORDER BY NAME_RUSSIAN
SQL корректно сортирует русские буквы. В одном операторе SQL можно комбинировать несколько условий, например:
SELECT * FROM DVD WHERE YEARF=2003 OR YEARF=2004
ORDER BY YEARF, NAME_RUSSIAN
Такой запрос означает: "выбрать из базы DVD такие записи, у которых в поле YEARF записано значение 2003 или 2004, а затем отсортировать их сначала по возрастанию значений в поле YEARF, а затем по алфавиту по полю NAME_RUSSIAN".
30.2. Понятие алиаса
Обратите внимание, что в приведенных примерах использования языка SQL после слова FROM указывается только имя файла БД без пути к нему. А как же наша программа узнает, где именно на диске лежит наш файл dvd.db?
Путь к БД, используемой той или иной программой, хранится не в самой этой программе, а в настройках сервера BDE. Оказывается он там двумя способами: либо при установке программы, либо программа сама прописывает этот путь в начале своей работы. Хранение пути вне программы снимает все вопросы, связанные с переносом файлов с машины на машину, на сетевой диск и т.д. – достаточно изменить путь алиаса при помощи программы BDE Administrator.
Пути к БД в BDE хранятся в виде алиасов (англ. alias – кличка). Каждый алиас имеет уникальное имя – его вы придумываете сами. В алиасе записываются тип используемой БД, путь к директории, где находятся файлы БД, и некоторые другие параметры (например, кодовая таблица символов или пароль доступа к БД).
Предположим, что файл dvd.db находится в директории С:\TEST\Data. Давайте сначала создадим алиас вручную. Запустите программу BDE Administrator (ее ярлык находится в разделе Borland Delphi главного меню). В дереве слева отображаются уже существующие на вашем компьютере алиасы.
Рис. 30.122 Экран программы BDE Administrator.
Выполните команду меню ObjectNew. В появившемся окошке преджлагается на выбор формат вашей БД. Для баз Paradox оставьте значение по умолчанию STANDARD. В дереве появляется новый пункт с именем по умолчанию типа STANDARD1. Поменяйте его на придуманное вами имя алиаса DVD. В окне справа щелкните по копке с тремя точками в строке PATH таблицы свойств алиаса (Рис. 30 .122). В открывшемся диалоге выберите директорию С:\TEST\Data. Все, алиас создан. Для сохранения внесенных изменений щелкните по кнопке и закройте BDE Administrator.
30.3. SQL в Delphi
Подключимся к нашей базе данных dvd.db с использованием алиасов и SQL. Снова создаем приложение и модуль данных.
На модуль данных надо поместить следующие компоненты:
- Session (закладка BDE);
- Database (закладка BDE);
- Query (закладка BDE).
Компонент Session (сессия) отвечает за управление работой BDE. Компонент Database (база данных) связывает программу с той директорией на диске, где находятся используемые файлы БД. Компонент Query (запрос) позволяет отправить запрос на SQL-сервер и получить с сервера выборку данных.
Рис. 30.123 Структура компонентов при доступе к распределенной БД
Дайте всем этим компонентам более короткие названия (поле Name в инспекторе объектов): Session вместо Session1; Database вместо Database1; DVD вместо Table1.
Компонент Session
Д ля этого компонента в инспекторе объектов надо задать следующие значения свойств:
Active - False. В начальный момент работы программы сессия должна быть закрыта.
SessionName – здесь вы вводите придуманное вами имя сессии, используемое во всех остальных компонентах. Например, можно назвать сессию DVDSes.
Остальные поля можно не трогать.
Компонент Database
Connected – False. В начальный момент работы программы база данных должна быть закрыта.
LoginPrompt – False. Данное свойство, будучи установленным в True, вызывает вывод окна ввода имени пользователя и пароля для подключения к БД.
DatabaseName - здесь вы вводите придуманное вами имя базы данных. Например, можно назвать сессию DVDDB.
SessionName – то имя сессии, которое вы ввели в поле SessionName компонента Session (его можно выбрать из раскрывающегося списка).
Компонент Query
Active – False. В начальный момент работы программы запрос должен быть закрыт.
DatabaseName - то имя базы данных, которое вы ввели в поле DataBaseName компонента Database (его можно выбрать из раскрывающегося списка).
SessionName – то имя сессии, которое вы ввели в поле SessionName компонента Session (его можно выбрать из раскрывающегося списка).
RequestLive – True. Если БД будет необходимо редактировать, данное свойство надо поставить в True.
SQL – самое главное свойство. Сюда заносится собственно текст SQL-запроса. В нашем случае это SELECT * FROM DVD