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

Московский Инженерно-Физический Институт

(Государственный университет)

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

По теме:”Разработка базы данных учета материально-технического оснащения кабинета специальной технологии колледжа №32 г. Москвы”

Научный руководитель: Кудрявцев К. Я.

Выполнила

Студентка группы К7-361

Панова Юлия

Москва, 2005 год

ОГЛАВЛЕНИЕ

Техническое задание. – 3 –

Литература. – 4 –

Отзыв о работе студента. – 4 –

Теоретическая часть. – 5 –

Реляционные базы данных. – 6 –

Visual FoxPro. – 6 –

Объекты Visual FoxPro. – 8 –

Что должна содержать база данных, чтобы сделать ее макс. эффективной? . – 10 –

Почему СУБД FoxPro? . – 11 –

Практическое выполнение учебно-исследовательской работы. – 12 –

Техническое задание на курсовой проект. – 13 –

Реляционная модель базы данных. – 14 –

Создание таблиц. – 17 –

Создание форм.. – 19 –

Форма “Главная форма ” . – 19 –

Форма “Уроки ” . – 20 –

Форма “Уроки (добавить новый)” . – 21 –

Форма “Информация по курсу” . – 22 –

Форма “Раздаточные материалы ” . – 23 –

Форма “Кассеты ” . – 25 –

Запросы.. – 26 –

Создание отчетов. – 28 –

Листинги обработчиков. – 30 –

Заключение по работе. – 39 –

МОСКОВСКИЙ ИНЖЕНЕРНО-ФИЗИЧЕСКИЙ ИНСТИТУТ

(ГОСУДАРСТВЕННЫЙ УНИВЕРСИТЕТ)

Кафедра ИНФОРМАЦИОННЫЕ ТЕХНОЛОГИИ

ТЕХНИЧЕСКОЕ ЗАДАНИЕ

На учебно-исследовательскую работу и курсовое

Проектирование

Студентки группы К7-361_Пановой Юлии

Тема:

Разработка базы данных учета материально-технического оснащения кабинета специальной технологии колледжа №32 г. Москвы в среде Visual FoxPro

Содержание технического задания:

Изучение литературы о возможностях и перспективах дальнейшего развития СУБД Visual FoxPro 8.0., о языке программирования FoxPro. Изучение структурированного языка запросов SQL. Изучение особенностей предметной области. Проектирование базы данных (создание реляционной модели) Создание основных элементов базы данных: таблиц, форм, отчетов, запросов. Разработка обработчиков событий на языке FoxPro.

Приборы для эксперимента:

СУБД VisualFoxPro8.0

ЛИТЕРАТУРА

Microsoft Visual FoxPro О. В. Бартеньев Диалог – МИФИ Москва 2005г. Visual FoxPro С. Каратыгин А. Тихонов Л. Тихонова Издательство БИНОМ Москва 1999 http://www. firststeps. ru/foxpro/fx/fx1.html http://omck. info/1subd. php http://www. computerbooks. ru/books/Programming/Book-FoxPro-7/index. html http://www. compdoc. ru/bd/foxpro/ http://www. linksoft. ru/working. html

Место выполнения УИР и КП_____каф.36__________________________

Руководитель________________________(Кудрявцев К. Я.)

Дата выдачи задания “____”__________________200__ г.

ОТЗЫВ О РАБОТЕ СТУДЕНТА

__________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________

__________________________________________________________________________________________________________________________________________________________

Руководитель__________________________”______”__________________200_г.

Теоретическая часть

Реляционные базы данных

В 1970 году статья научного сотрудника компании IBM доктора Е. Ф. Коддао реляционной модели данных произвела революцию в подходе к хранению и обработке информации. На основе этой модели в семидесятые годы были разработаны первые реляционные базы данных, а в настоящее время они рассматриваются как стандарт для современных коммерческих СУБД.

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

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

Visual FoxPro.

Visual FoxPro – не просто следующая версия одной из наиболее быстрых СУБД для персональных компьютеров. Это совершенно новая программа, которая легко позволяет сделать то, что в предыдущих версиях давалось с величайшим трудом или было просто недоступно. Интерфейс Visual FoxPro отвечает представлениям о современной графической среде, напоминая интерфейс иных программ Microsoft. Здесь основная работа с данными выполняется с помощью различных инструментальных средств, поэтому команды меню часто имеют вспомогательный характер и их состав гибко меняется в зависимости от того, какое средство активно в данный момент. Отличительные черты Visual FoxPro можно описать следующим образом:

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

2. Обеспечение полного набора средств для управления событиями.

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

4. Обеспечение полной интеграции Visual FoxPro в семейство прикладных программ Micrpоsoft. Единый интерфейс с наиболее популярными прикладными программами Microsoft делает работу в интерактивном режиме интуитивно понятной. Поддержка правой кнопки мыши позволяет избежать долгих путешествий по системе меню и значительно облегчает изучение новых возможностей СУБД. Просто выберите курсором объект и нажмите правую кнопку мыши. На некоторых диалоговых окнах, которые часто используются в работе на полосе заголовка, появился переключатель в виде анимационной пиктограммы (push pin), позволяющий легко включить режим, при котором это окно будет всегда расположено на переднем плане. Visual FoxPro обеспечивает полную поддержку OLE 2.0, что облегчает взаимодействие с другим программным обеспечением в среде WINDOWS. Помимо оставшейся возможности загрузки внешних функций посредством команды SET LIBRARY появилась возможность обращения к функциям динамических DLL библиотек WINDOWS посредством команды DECLARE.

5. Совместимость с ранее разработанным обеспечением в среде FoxPro.

Основные преимущества

Основное назначение

Visual FoxPro

Высокий уровень объектной модели. Высокая скорость обработки данных. Интеграция объектно-ориентированного языка программирования с Xbase и SQL. Многоплатформенность.

Создание приложений масштаба предприятия. Создание приложений для работы на различных платформах (Windows 3.x, Windows 95, Macintosh и т. д.)

Объекты Visual FoxPro

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

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

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

Для отображения и редактирования данных используются формы, отчеты, запросы и программы. При создании форм, отчетов и запросов применяются конструкторы. Поэтому эти компоненты часто называют конструкторскими объектами. Формы и отчеты являются составными объектами, т. к. они состоят из более мелких объектов (таких как поля, кнопки, диаграммы, рамки, OLE – компоненты и т. п.), которые называются объектами интерфейса.

Формы используются для просмотра или ввода данных в таблицы. Данные можно вводить непосредственно в таблицы, но использование формы является более быстрым и более эффективным способом ввода. Форма содержит некоторые или все поля таблиц, в которые вы вводите информацию. Для создания форм вы можете использовать мастер создания форм или конструктор форм. Мастер форм содержит целый ряд шаблонов, которые определяют соотношение между помещаемыми в форму таблицами, вид отображения данных и порядок размещения полей. Для создания сложных форм применяется конструктор форм.

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

Запросы являются средством выборки данных из одной или нескольких таблиц. В Visual FoxPro для создания запроса вы можете использовать как конструктор запросов, так и специализированный язык Structured Query Language (SQL). Результаты выполнения запроса могут отображаться в форме, выводиться в виде отчетов и диаграмм или сохраняться в указанной вами таблице.

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

Для создания форм в Visual FoxPro можно использовать не только базовые классы, но и создавать собственные. Например, вы можете определить класс форм, в котором задан определенный цвет фона и стандартный набор кнопок для управления данными. Чтобы стандартизировать разработку, полезно иметь один или несколько пользовательских классов для каждого базового класса. Классы, созданные в Visual FoxPro, хранятся в библиотеках классов.

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

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

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

Таблица 1. Расширения имен файлов объектов Visual FoxPro

Наименование объекта

Расширения

Проект

PRJ, FPC, CAT, PJX, PJT

База данных

DBC

Таблица Visual FoxPro

DBF

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

CDX

Memo-поле и поле типа General

FRT

Форма

Sex

Запрос

QPR

Отчет

FRX, FRM

Почтовая наклейка

LBX, LBL

Меню

MNX

Библиотека класса

VCX

Программа, библиотека программ, текст меню, текст запроса

PRG, FXP, MPR, QPR

Рисунок

BMP, JPG, GIF, ICO, DIB, CUR, ANI

Звукозапись

WAV

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

Существует очень простое понятие БД как большого по объему хранилища, в которое организация помещает все используемые ею данные и из которого различные пользователи могут их получать, используя различные приложения. Такая единая база данных представляется идеальным вариантом, хотя на практике это решение по различным причинам труднодостижимо. Поэтому чаще всего под базой данных понимают любой набор хранящихся в компьютере взаимосвязанных данных. В основу проектирования БД должны быть положены представления конечных пользователей конкретной организации – концептуальные требования к системе. Именно конечный пользователь в своей работе принимает решения с учетом получаемой в результате доступа к базе данных информации. От оперативности и качества этой информации будет зависеть эффективность работы организации. Данные, помещаемые в базу данных, также предоставляет конечный пользователь. При рассмотрении требований конечных пользователей необходимо принимать во внимание следующее:

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

Почему СУБД FoxPro?

FoxPro – одна из наиболее эффективных настольных СУБД. Данный продукт принадлежит компании Microsoft и тесно интегрирован с другими его продуктами. Единый интерфейс с наиболее популярными прикладными программами Microsoft делает работу в интерактивном режиме интуитивно понятной.

FoxPro обладает собственным внутренним механизмом управления реляционной БД, тесной взаимосвязью между языком и данными, полноценными возможностями объектно-ориентированного программирования и широким спектром функций VFP 8.0 позволяет создавать производительные, масштабируемые БД-ориентированные решения с поддержкой баз данных с таблицами объемом до 2 Гб. При этом VFP 8.0 выгодно отличается от других инструментов Microsoft умеренными системными требованиями и высокой эффективностью разрабатываемых приложений (производительность, размеры БД и программного кода).

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

При этом FoxPro был и продолжает оставаться одним из самых популярных инструментальных средств в России (в отличие от западных стран), для изучения которого имеется хорошая информационно-методическая база (книги, специализированные журналы, центры обучения и пр.).

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

Техническое задание на курсовой проект.

Задача проекта состоит в разработке базы данных по учету материально-технического оснащения кабинета специальной технологии с целью наиболее полной и тщательной подготовки учебного материала.

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

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

Данная задача определена преподавателем специальной технологии колледжа №32 города Москвы Пановой Е. В.(учебный курс предназначен для поваров-кондитеров)

База данных должна отвечать следующим требованиям:

    Ввод информации об уроках по специальной технологии (курс, месяц, номер урока, тема урока). Ввод информации о материально-техническом оснащении кабинета:

      Кассеты (название кассеты; длительность; номера уроков, к которым относится кассета) Раздаточные материалы (название раздаточного материалы; вид; номера уроков, к которым относится раздаточный материал)
    К любому уроку может относиться несколько кассет и раздаточных материалов, точно также, как и каждое из перечисленных может относиться к нескольким урокам одновременно. Ввод информации по курсу (курс; количество часов, читаемых по курсу; количество групп, относящихся к курсу) Возможность просмотра по выбранному уроку списка учебных материалов, относящихся к нему (информация должна выдаваться пользователю в виде отчета). Возможность просмотра списка уроков преподаваемых за конкретный месяц и суммарный подсчет общего количества уроков за данный период (информация должна содержаться в виде отчета). Возможность просмотра списка уроков преподаваемых на 1, 2 и 3 курсах (информация должна содержаться в виде отчета). Возможность просмотра списка уроков, относящегося к кассете и раздаточному материалу. Возможность поиска урока по названию его темы. Возможность сортировки уроков по курсу и номеру урока. Разработка интерфейса должна отвечать индивидуальным требованиям заказчика. Возможность проверки корректности вводимых данных. База данных создается с помощью СУБД FoxPro, необходимые обработчики создаются с использованием языка FoxPro

Реляционная модель базы данных.

Рис. 1.Реляционная модель базы данных.

Реляционная модель базы данных представляет собой совокупность таблиц, представляющих объектные множества, поля (строки) которых представляют... собой их атрибуты. Для задания связей между таблицами, необходимо определить дополнительные поля, содержащие коды элементов связанных таблиц. Для связи объектных множеств “Уроки” и “Кассета”, а также “Уроки” и “Раздаточные материалы” вводится дополнительные таблицы связей ” Уроки-Кассеты” и “Уроки-Раздаточные материалы”типа многие ко многим, содержащие ключевые поля связанных элементов.

В данной модели рассматриваются шесть объектных множеств. Атрибут “ID номер”, присутствующий у каждого объектного множества, необходим для однозначной идентификации каждого элемента множества.

1) Объектное множество “Уроки”

    ID урока Курс Месяц Номер урока Тема урока

Служит для описания уроков предмета спец. технологии.

2) Объектное множество “Кассеты”

    ID кассеты Название кассеты Длительность кассеты

Служит для описания кассет, входящих в состав материально-технического оснащения кабинета.

3) Объектное множество “Раздаточные материалы”

    ID раздаточного материала Название раздаточного материала Вид раздаточного материала

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

4) Объектное множество “Уроки-Кассеты”

    ID кассеты ID урока

Служит для связи двух объектных множеств “Уроки” и “Кассеты” (реализация связи многие ко многим).

5) Объектное множество “Уроки-Раздаточные материалы”

    ID раздаточного материала ID урока

Служит для связи двух объектных множеств “Уроки” и “Раздаточные материалы” (реализация связи многие ко многим).

6) Объектное множество “Курс”

    Курс Количество часов Количество групп

Служит для описания дополнительной информации, относящейся курсу.

Между объектными множествами установлены отношения:

1) Объектное множество “Уроки” связано с объектным множеством “Уроки-Кассеты” отношением один ко многим, так как для каждого урока может существовать несколько кассет, относящихся к данному уроку.

2) Объектное множество “Кассеты” связано с объектным множеством “Уроки-Кассеты” отношением один ко многим, так как каждая кассета может относиться к нескольким урокам.

3) Объектное множество “Уроки” связано с объектным множеством “Уроки-Раздаточные материалы” отношением один ко многим, так как для каждого урока может существовать несколько раздаточных материалов, относящихся к данному уроку.

4) Объектное множество “Раздаточные материалы” связано с объектным множеством “Уроки-Раздаточные материалы” отношением один ко многим, так как каждый раздаточный материал может относиться к нескольким урокам.

5) Объектное множество “Курс” связано с объектным множеством “Уроки” отношением один ко многим, так как к каждому курсу относится несколько уроков, тогда как каждый урок однозначно принадлежит определенному курсу.

Создание таблиц.

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

Основные параметры, используемые в таблицах БД:

– Название поля

– Тип поля

– Ширина поля

– Наличие индексации поля

Основная особенность данной БД заключается в том, что все таблицы являются свободными.

Рис. № 2 Вид таблицы “Уроки” в режиме конструктора

Рис. №3 Вид таблицы “Кассеты” в режиме конструктора

Рис. № 4 Вид таблицы “Раздаточные материалы” в режиме конструктора

Рис. №5 Вид таблицы “Курс ” в режиме конструктора

Рис. № 6 Вид таблицы “Уроки-кассеты ” в режиме конструктора

Рис. №7 Вид таблицы “Уроки-Раздаточные материалы ” в режиме конструктора

Создание форм

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

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

Форма ” Главная форма “

Рис. №8 Форма “Главная форма”

При запуске программы перед пользователем появляется “Основная форма”, показывающая ссылки (кнопки) на основные компоненты БД и позволяющая быстро переместится в интересующую его область.

Кнопки формы:

    Кнопка “Уроки” закрывает данную форму и открывает форму “Уроки” Кнопка “Метод. материалы” закрывает данную форму и открывает форму “Методические материалы” Кнопка “Кассеты” закрывает данную форму и открывает форму “Кассеты” Кнопка “Выход” завершает работу программы.

Форма ” Уроки “

Рис. №9 Форма “Уроки”

Форма “Уроки” является простой однотабличной формой (основанной на таблице “Уроки”), созданной в режиме конструктора. Служит для удобного просмотра необходимой информации по урокам. Требование к виду и типу информации приведены ранее в техническом задании к учебно-исследовательской работе.

Форма позволяет:

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

Кнопки формы:

    Кнопка “Поиск” осуществляет поиск нужного урока по названию его темы (или по введенным первым символам темы). Если данное поле найдено в списке, для продолжения поиска, необходимо нажать кнопку “Далее”. Кнопка “Далее” продолжает поиск нужного урока в списке. Кнопка “Обновить” позволяет обновить данные в форме. Кнопка “Выход” закрывает данную форму и открывает “Основную”. Кнопка “Просмотреть информацию по курсу” открывает новую форму “Курс” Кнопка “Добавить” открывает новую форму “Уроки (добавить новый)” Кнопка “Удалить” удалят запись по идентифицирующему номеру урока Кнопка “Изменить” позволяет изменять любые данные, кроме идентифицирующего номера урока Кнопка “Показать” выводит на экран список необходимой информации по урокам Кнопка “Сохранить” сохраняет измененные данные (кнопка невидима до тех пор, пока пользователь не нажал кнопку “Изменить”)

– по кассетам: выводит список кассет, относящихся к данному уроку.

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

– список уроков за месяц: выводит список уроков, проведенных за месяц.

Форма “Уроки (добавить новый)”

Рис. №10 Форма “Уроки (добавить новый)”

Форма “Уроки (добавить новый)” является простой однотабличной формой (основанной на таблице “Уроки”), созданной в режиме конструктора.

Форма позволяет:

    Вносить новые данные по урокам

Поля формы:

    поле курс: содержит перечень курсов (1,2,3) поле месяц: содержит список учебных месяцев (сентябрь-май) поле номер урока: определяет номер урока поле количество внесенных уроков: заполняется автоматически согласно выбору курса поле тема урока: определяет название темы урока

Кнопки формы:

    Кнопка “Сохранить” сохраняет внесенные в форму данные. Кнопка “Выход” закрывает данную форму.

Форма “Информация по курсу”

Рис. №11 Форма “Информация по курсу”

Форма ” Информация по курсу” является простой однотабличной формой (основанной на таблице “Курс”), созданной в режиме конструктора.

Форма позволяет:

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

Кнопки формы:

    Кнопка “Изменить” позволяет изменять любые данные, кроме курса
    Кнопка “Сохранить” сохраняет внесенные изменения. Кнопка “Выход” закрывает данную форму. Кнопка “Отчет по курсу” формирует список проведенных уроков за курс

Форма ” Раздаточные материалы “

Рис. №12 Форма “Раздаточные материалы”

Данная конструкция основана на понятии набора форм ( FormSet). Использование набора необходимо для синхронизации форм “Раздаточные материалы” и “Таблица уроков” .

В конструкции используются три таблицы “Уроки”, “Раздаточные материалы” и “Уроки-Раздаточные материалы”. Набор создается в режиме конструктора. Требование к виду и типу информации приведены ранее в техническом задании к учебно-исследовательской работе.

Форма “Раздаточные материалы” позволяет:

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

Поля формы

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

Кнопки формы:

    Кнопка “Первая” возвращает указатель на первый элемент из списка Кнопка “Последняя” возвращает указатель на последний элемент из списка Кнопка “Следующая” переводит указатель на следующий элемент по списку Кнопка “Предыдущая” возвращает указатель на предыдущий элемент из списка значений. Кнопка “Добавить” очищает поля ввода, причем после нажатие этой кнопки остальные кнопки становятся недоступными, за исключением кнопок “Удалить” и “Сохранить”. Если после нажатия кнопки “Добавить”, пользователь передумал вносить новые данные, для выхода из этого режима необходимо нажать кнопку “Удалить”, если запись все же нужно внести, после заполнения полей необходимо нажать кнопку “Сохранить”, тогда данные будут сохранены в таблице. Кнопка “Удалить” удаляет разд. материал, разрывая все существующие связи с уроками.
    Кнопка “Сохранить” сохраняет измененные данные Кнопка “Выход” закрывает набор форм и возвращается к основной форме Кнопка “Показать таблицу уроков” делает видимой форму “Таблица уроков”, данная форма необходима, для определение идентификационного номера урока, к которому пользователь желает отнести урок или, наоборот, открепить от урока. Кнопка “Открепить от урока” открепляет данный раздаточный материал от урока Кнопка “Прикрепить к уроку” прикрепляет данный раздаточный материал к уроку

Форма “Таблица уроков” позволяет:

    Показать таблицу уроков

Кнопки формы:

    Кнопка “Скрыть таблицу” делает форму невидимой

Форма ” Кассеты “

Рис. №13 Форма “Кассеты”

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

Используются три таблицы “Уроки”, “Кассеты” и “Уроки-Кассеты”.

Запросы

Рис. №14 запрос”Поиск”

Рис. №15 запрос “Удаление урока”

Рис. №16 запрос “Список уроков за месяц”

Рис. №17 запрос”Прикрепление и открепления урока от материала”

Рис. №18 запрос “Список уроков за курс”

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

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

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

Создание отчетов.

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

Рис. №19 Отчет “Список кассет, относящихся к данному уроку”

Рис. №20 Отчет “Список раздаточных материалов, относящихся к данному уроку”

Рис. №21 Отчет “Количество уроков проведенных за месяц”

Рис. №22 Отчет “Список уроков за курс”

Листинги обработчиков.

Обработчик кнопки “Выход” основной формы.

IF MESSAGEBOX(‘Выйти из программы?’, 4 + 32 + 256, ‘Выход’)=6

_screen. ActiveForm. Release()

CLEAR EVENTS

QUIT

ELSE

_screen. ActiveForm. Refresh()

ENDIF

Обработчик события сортировки данных таблицы формы “Уроки”.

IF this. Value=1 then

Thisform. DataEnvironment. cursor1.order=’kurs_id’

ELSE

Thisform. DataEnvironment. cursor1.order=’num_lesson’

ENDIF

Thisform. grid1.Refresh

Обработчик события кнопки “Поиск” формы “Уроки”.

PUBLIC found_lesson

With thisform

Found_lesson =INPUTBOX(‘Введите тему урока или ее начало’,’Поиcк’)

IF NOT EMPTY(found_lesson)

&;&;Задает правила, согласно которым Visual FoxPro сравнивает две строки разной длины

&;&;OFF(По умолчанию) Указывает, что выражения будут эквивалентны, если они совпадают посимвольно вплоть до конца выражения, расположенного справа.

SET EXACT OFF

S=RECNO()

LOCATE FOR Uir_tab_lesson. nam_lesson= found_lesson

IF NOT FOUND() THEN &;&; все хорошо и запись (и) найдены

Messagebox(‘Поиск не дал результатов’,48)

&;&; Возврат к записи с которой был начат поиск

GO s

.Command7.Enabled=.f.

ELSE

.command7.Enabled=.t.

ENDIF

ENDIF

.grid1.setfocus

ENDWITH

Обработчик события кнопки “Далее” формы “Уроки”.

SET EXACT OFF

S=RECNO()

&;&; Поиск следующей, отвеч. строке поиска записи

CONTINUE

IF NOT FOUND()

GO s

This. Enabled= .F.

ENDIF

ThisForm. Grid1.SetFocus

Обработчик события кнопки “Обновить” формы “Уроки”.

_screen. ActiveForm. refresh()

IF thisform. Optiongroup1.Value=1 then

Thisform. DataEnvironment. cursor1.order=’kurs_id’

ELSE

Thisform. DataEnvironment. cursor1.order=’num_lesson’

ENDIF

Thisform. grid1.Refresh

Обработчик события кнопки “Показать” формы “Уроки”.

IF Thisform. Optiongroup2.Option1.Value=1

Uuu=INPUTBOX(‘Введите ID урока’,’Заявка’)

T=val(uuu)

IF EMPTY(uuu)=.f. then

SELECT Uir_tab_kasseta. name_kas, Uir_tab_kasseta. time_kas;

FROM ;

Uir_tab_lk INNER JOIN uir_tab_kasseta ;

ON Uir_tab_lk. kass_id = Uir_tab_kasseta. kass_id;

WHERE Uir_tab_lk. lesson_id = t;

INTO TABLE time_tab7

REPORT FORM uir_report7 preview

SELECT time_tab7

DELETE ALL

PACK

ELSE thisform. Refresh

Endif

ENDIF

IF Thisform. Optiongroup2.Option2.Value=1

Uuu=INPUTBOX(‘Введите ID урока’,’Заявка’)

T=val(uuu)

IF EMPTY(uuu)=.f. then

SELECT Uir_tab_mat. name_mat, Uir_tab_mat. vid_mat;

FROM uir_tab_lm INNER JOIN uir_tab_mat ;

ON Uir_tab_lm. mat_id = Uir_tab_mat. mat_id;

WHERE Uir_tab_lesson. lesson_id = t;

INTO TABLE time_tab8

REPORT FORM uir_report8 preview

SELECT time_tab8

DELETE ALL

Pack

ELSE thisform. Refresh

Endif

ENDIF

IF Thisform. Optiongroup2.Option3.Value=1

PUBLIC uuu_mes

Uuu_mes=INPUTBOX(‘Введите месяц’,’Заявка’)

IF EMPTY(uuu_mes)=.f. then

SELECT Uir_tab_lesson. kurs_id, Uir_tab_lesson. num_lesson,;

Uir_tab_lesson. nam_lesson;

FROM uir_tab_lesson;

WHERE Uir_tab_lesson. mes_id = uuu_mes;

INTO TABLE time_tab1

REPORT FORM uir_report4 preview

SELECT time_tab1

DELETE ALL

PACK

ELSE thisform. Refresh

Endif

ENDIF

Обработчик события кнопки “Удалить” формы “Уроки”.

Uuuz=INPUTBOX(‘Введите ID урока, который желаете удалить’,’Удаление записи из таблицы’)

IF EMPTY(uuuz)=.f. then

DO WHILE Type(uuuz)!=’N’

MESSAGEBOX(‘Вы ввели некорректное значение (ID числовое значение)’)

Uuuz=INPUTBOX(‘Введите ID урока, который желаете удалить’,’Удаление записи из таблицы’)

ENDDO

Tu=val(uuuz)

LOCAL ARRAY ss1(20)

SELECT Uir_tab_lesson. nam_lesson;

FROM uir_tab_lesson;

WHERE Uir_tab_lesson. lesson_id =tu;

INTO ARRAY ss1

If EMPTY(ss1)

MESSAGEBOX(‘Такого значения ID нет в списке данных’)

Else

SELECT Uir_tab_lesson

DELETE;

FROM Uir_tab_lesson;

WHERE uir_tab_lesson. lesson_id = tu

PACK

SELECT Uir_tab_lm

DELETE;

FROM Uir_tab_lm;

WHERE uir_tab_lm. lesson_id = tu

PACK

SELECT Uir_tab_lk

DELETE;

FROM Uir_tab_lk;

WHERE uir_tab_lk. lesson_id = tu

PACK

_screen. ActiveForm. Release()

DO FORM uir_les_form8

ENDIF

ELSE Thisform. Refresh

ENDIF

Обработчик события кнопки “Первая” формы “Раздаточные материалы”.

IF! BOF()

GO TOP

ENDIF

_screen. ActiveForm. Refresh()

Ee1=thisform. Text1.Value

SELECT Uir_tab_lesson. nam_lesson;

FROM uir_tab_mat INNER JOIN uir_tab_lm ;

ON Uir_tab_mat. mat_id = Uir_tab_lm. mat_id ;

INNER JOIN uir_tab_lesson ;

ON Uir_tab_lm. lesson_id = Uir_tab_lesson. lesson_id;

WHERE Uir_tab_mat. mat_id =ee1;

INTO ARRAY less1

IF ISNULL(less1)

Less1[1]=’ ‘

ENDIF

Thisform. List1.Refresh

Обработчик события кнопки “Следущая” формы “Раздаточные материалы”.

IF! EOF()

SKIP

ENDIF

_screen. ActiveForm. Refresh()

Ee1=thisform. Text1.Value

SELECT Uir_tab_lesson. nam_lesson;

FROM uir_tab_mat INNER JOIN uir_tab_lm ;

ON Uir_tab_mat. mat_id = Uir_tab_lm. mat_id ;

INNER JOIN uir_tab_lesson ;

ON Uir_tab_lm. lesson_id = Uir_tab_lesson. lesson_id;

WHERE Uir_tab_mat. mat_id =ee1;

INTO ARRAY less1

IF ISNULL(less1)

Less1[1]=’ ‘

ENDIF

Thisform. List1.Refresh

Обработчик события кнопки “Предыдущая” формы “Раздаточные материалы”.

IF! BOF ( )

SKIP – 1

ENDIF

_screen. ActiveForm. Refresh ()

Ee1=thisform. Text1.Value

SELECT Uir_tab_lesson. nam_lesson;

FROM uir_tab_mat INNER JOIN uir_tab_lm ;

ON Uir_tab_mat. mat_id = Uir_tab_lm. mat_id ;

INNER JOIN uir_tab_lesson ;

ON Uir_tab_lm. lesson_id = Uir_tab_lesson. lesson_id;

WHERE Uir_tab_mat. mat_id =ee1;

INTO ARRAY less1

IF ISNULL(less1)

Less1[1]=’ ‘

ENDIF

Thisform. List1.Refresh

Обработчик события кнопки “Последняя ” формы “Раздаточные материалы”.

IF! EOF()

GO BOTTOM

ENDIF

_screen. ActiveForm. Refresh( )

Ee1=thisform. Text1.Value

SELECT Uir_tab_lesson. nam_lesson;

FROM uir_tab_mat INNER JOIN uir_tab_lm ;

ON Uir_tab_mat. mat_id = Uir_tab_lm. mat_id ;

INNER JOIN uir_tab_lesson ;

ON Uir_tab_lm. lesson_id = Uir_tab_lesson. lesson_id;

WHERE Uir_tab_mat. mat_id =ee1;

INTO ARRAY less1

IF ISNULL(less1)

Less1[1]=’ ‘

ENDIF

Thisform. List1.Refresh

Обработчик события кнопки “Добавить ” формы “Раздаточные материалы”.

PUBLIC new_mat_id as Integer

SET ORDER TO mat_id

CALCULATE MAX(mat_id) TO new_mat_id

New_mat_id=new_mat_id+1

CLEAR

SELECT uir_tab_mat

APPEND BLANK

ThisForm. Text1.Value=new_mat_id

Ee=thisform. Text1.Value

RELEASE less1

DIMENSION less1(20)

Thisform. List1.Refresh

_screen. ActiveForm. Refresh( )

Thisform. Command4.Visible= .T.

Thisform. Command2.Enabled= .f.

Thisform. Commandgroup1.Command1.Enabled= .F.

Thisform. Commandgroup1.Command2.Enabled= .F.

Thisform. Commandgroup1.Command3.Enabled= .F.

Thisform. Commandgroup1.Command4.Enabled= .F.

Thisform. Commandgroup1.Command5.Enabled= .F.

Thisform. Commandgroup1.Command8.Enabled= .F.

Обработчик события кнопки “Удалить” формы “Раздаточные материалы”.

Tu=thisform. Text1.value

IF MESSAGEBOX(‘Вы уверены, что хотите стереть запись?’, 4 + 32 + 256, ‘Выход’)=6

SELECT uir_tab_mat

SET EXCLUSIVE ON

DELETE

Pack

SELECT uir_tab_lm

SET EXCLUSIVE ON

DELETE;

FROM Uir_tab_lm;

WHERE Uir_tab_lm. mat_id = tu

PACK

_screen. ActiveForm. Release()

DO FORM uir_form21

MESSAGEBOX(‘Данные удалены из таблицы!’)

ELSE

_screen. ActiveForm. Refresh()

Endif

Обработчик события кнопки “Открепить от урока” формы “Раздаточные материалы”.

Tu=thisform. Text1.value

Uuu=INPUTBOX(‘Введите ID урока’,’Заявка’)

IF EMPTY(uuu)=.f. then

DO WHILE Type(uuu)!=’N’

MESSAGEBOX(‘Вы ввели некорректное значение (ID числовое значение)’)

Uuu=INPUTBOX(‘Введите ID урока’,’Заявка’)

ENDDO

Ttz=val(uuu)

LOCAL ARRAY ss7(20)

SELECT Uir_tab_lm. mat_id;

FROM uir_tab_lm;

WHERE Uir_tab_lm. mat_id = ttz;

INTO ARRAY ss7

If EMPTY(ss7)

MESSAGEBOX(‘Данная кассета не содержится в списке’)

ELSE

SELECT uir_tab_lm

DELETE;

FROM Uir_tab_lm;

WHERE Uir_tab_lm. lesson_id =ttz and Uir_tab_lm. mat_id=tu

PACK

THISFORMset. forms(2).visible=.f.

_screen. ActiveForm. Release()

DO FORM uir_form20

MESSAGEBOX(‘Связь разорвана!’)

Endif

ELSE thisform. Refresh

Endif

Обработчик события кнопки “Прикрепить к уроку” формы “Раздаточные материалы”.

SELECT uir_tab_lm

Uuu=INPUTBOX(‘Введите ID урока’,’Заявка’)

IF EMPTY(uuu)=.f. then

DO WHILE Type(uuu)!=’N’

MESSAGEBOX(‘Вы ввели некорректное значение (ID числовое значение)’)

Uuu=INPUTBOX(‘Введите ID урока’,’Заявка’)

ENDDO

Tz=val(uuu)

LOCAL ARRAY ss6(20)

SELECT Uir_tab_lesson. nam_lesson;

FROM uir_tab_lesson;

WHERE Uir_tab_lesson. lesson_id =tz;

INTO ARRAY ss6

If EMPTY(ss6)

MESSAGEBOX(‘Такого значения ID нет в списке данных’)

ELSE

LOCAL ARRAY ss5(20)

SELECT Uir_tab_lm. mat_id;

FROM uir_tab_lm;

WHERE Uir_tab_lm. lesson_id = tz;

INTO ARRAY ss5

If EMPTY(ss5)=.f.

MESSAGEBOX(‘Такая кассета уже есть в списке’)

Else

Y=thisform. Text1.Value

INSERT INTO uir_tab_lm VALUES (tz, y)

THISFORMset. forms(2).visible=.f.

_screen. ActiveForm. release

DO FORM uir_form21

Endif

Endif

ELSE thisform. Refresh

Endif

Обработчик события кнопки “Сохранить” формы “Уроки (добавить новый)”.

LOCAL qt as Character;

Yy as Integer;

Rt as Integer;

Wu=ThisForm. Text5.Value

Yy=ThisForm. Text4.Value

Qt=ThisForm. Combo2.Value

Rt=ThisForm. Combo1.Value

Wt=VAL(yy)

T=new_lesson_id

IF EMPTY(wu)

IF EMPTY(yy)

IF EMPTY (qt)

IF EMPTY(rt)

MESSAGEBOX(‘Данные не были введены!’)

ELSE

INSERT INTO uir_tab_lesson VALUES (t, rt, qt, wt, wu)

MESSAGEBOX(‘Данные добавлены в таблицу!’)

Thisform. Command1.Enabled= .f.

_screen. ActiveForm. Release()

DO FORM uir_form12

ENDIF

ELSE

INSERT INTO uir_tab_lesson VALUES (t, rt, qt, wt, wu)

MESSAGEBOX(‘Данные добавлены в таблицу!’)

Thisform. Command1.Enabled= .f.

_screen. ActiveForm. Release()

DO FORM uir_form12

ENDIF

ELSE

INSERT INTO uir_tab_lesson VALUES (t, rt, qt, wt, wu)

MESSAGEBOX(‘Данные добавлены в таблицу!’)

Thisform. Command1.Enabled= .f.

_screen. ActiveForm. Release()

DO FORM uir_form12

ENDIF

ELSE

INSERT INTO uir_tab_lesson VALUES (t, rt, qt, wt, wu)

MESSAGEBOX(‘Данные добавлены в таблицу!’)

Thisform. Command1.Enabled= .f.

_screen. ActiveForm. Release()

DO FORM uir_form12

ENDIF

Заключение по работе.

Целью учебно-исследовательской работы являлось:

    Изучение СУБД Visual FoxPro 8.0.и языка программирования FoxPro. Изучение структурированного языка запросов SQL. Изучение особенностей предметной области. Проектирование базы данных (создание реляционной модели) Создание основных элементов базы данных: таблиц, форм, отчетов, запросов. Разработка обработчиков событий на языке FoxPro. Приобретение навыков работы с СУБД Visual FoxPro 8.0

Курсовой проект посвящен разработке базы данных для учета материально-технического оснащения кабинета специальной технологии колледжа №32 г. Москвы

В ходе УИР и КП создана база данных, отвечающая техническому заданию на курсовой проект, с использованием средств FoxPro 8.0.

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

ЛИТЕРАТУРА

Microsoft Visual FoxPro О. В. Бартеньев Диалог – МИФИ Москва 2005г. Visual FoxPro С. Каратыгин А. Тихонов Л. Тихонова Издательство БИНОМ Москва 1999 http://www. firststeps. ru/foxpro/fx/fx1.html http://omck. info/1subd. php http://www. computerbooks. ru/books/Programming/Book-FoxPro-7/index. html http://www. compdoc. ru/bd/foxpro/ http://www. linksoft. ru/working. html


Зараз ви читаєте: Разработка базы данных учета материально-технического оснащения кабинета специальной технологи