База данных
Курсовая работа, 27 Марта 2011, автор: пользователь скрыл имя
Описание работы
Данная курсовая есть результат работы, выполненной в ходе изучения дисциплины “Базы данных”. В качестве задания необходимо создать программу, предназначенную для работы с базой данных, содержащей в себе информацию об учебных планах. На мой взгляд, были выполнены все требования и пожелания преподавателя касаемо функционирования и представления данных.
Содержание работы
1.Введение………………………………………………………………………...3
2.Задача
a.Предметная область и ER-диаграмма……………….………………………………………………..4
b.Физическая модель данных (макеты таблиц)…………………………. 5
c.Список явных ограничений целостности……………………………………………………………….6
3.Описание приложения
a.Функции и процедуры, а так же связи.......………………………...……7
b.Классы, их методы и поля класса………………………………………25
4.Описание функционирования базы данных
a.Процедуры и функции по реализации ограничений целостности, включая SQL запросы……………………………………………….......28
b.SQL запросы по ведению электронного аналога документа…………………………………………………………….…..29
5.Описание экранных форм……………………………………………………...30
6.Руководство по эксплуатации………………………………………………....31
7.Заключение…………………………………………………………………..….32
8.Список литературы………………………………………………………..……33
9.Приложение……………………………………………………………….….…34
Файлы: 1 файл
Курсовая работа.docx
— 546.75 Кб (Скачать файл)Пояснительная записка к курсовой работе
по дисциплине «Базы данных»
ФЕДЕРАЛЬНОЕ АГЕНТСТВО ПО ОБРАЗОВАНИЮ
ГОСУДАРСТВЕННОЕ ОБРАЗОВАТЕЛЬНОЕ УЧРЕЖДЕНИЕ
ВЫСШЕГО
ПРОФЕССИОНАЛЬНОГО
ОБРАЗОВАНИЯ
ТИХООКЕАНСКИЙ
ГОСУДАРСТВЕННЫЙ
УНИВЕРСИТЕТ
Хабаровск 2010
| Выполнил: | Ермаков А.В. ВМ-81 |
| Проверил: | Федосеев А. А. |
Содержание
- Введение…………………………………………………………
……………...3 - Задача
- Предметная
область и ER-диаграмма……………….……………………………
…………………..4 - Физическая модель данных (макеты таблиц)…………………………. 5
- Список явных
ограничений целостности…………………………………………………
…………….6 - Описание приложения
- Функции и процедуры, а так же связи.......………………………...……7
- Классы, их методы и поля класса………………………………………25
- Описание функционирования базы данных
- Процедуры
и функции по реализации ограничений целостности,
включая SQL запросы……………………………………………….
......28 - SQL запросы
по ведению электронного аналога документа………………………………………………………
…….…..29 - Описание экранных форм……………………………………………………...30
- Руководство
по эксплуатации………………………………………………
....31 - Заключение……………………………………………………
……………..….32 - Список литературы……………………………………………………
…..……33 - Приложение……………………………………………………
………….….…34
Введение
Данная курсовая есть результат работы, выполненной в ходе изучения дисциплины “Базы данных”. В качестве задания необходимо создать программу, предназначенную для работы с базой данных, содержащей в себе информацию об учебных планах. На мой взгляд, были выполнены все требования и пожелания преподавателя касаемо функционирования и представления данных. Работа была сопряжена с «двигателем» базы данных SQLite, средой QT, и генератором отчётов eXaro. Были реализованы необходимые запросы для функционирования базы, а также реализована возможность отображения в отчёте только тех данных, которые попали в результат поиска, что значительно повышает ценность данного приложения.
Описание предметной области
Разработанное
приложение предназначено для ведения
базы данных, содержащей в себе информацию
об учебных планах. С помощью этого приложения
можно добавлять и удалять из базы дисциплины,
преподавателей, студентов и учебные планы,
диски, просматривать содержимое базы
данных и многое др. Выходным документом
является отчёт, который формируется в
зависимости от выбранного студента. База
отвечает на вопросы: какие дисциплины
будет вести преподаватель у студентов,
обучающихся по индивидуальному плану
в 2003 году? С какими студентами, обучающимися
по индивидуальному плану, предстоит работать
преподавателю по предмету «Компьютерная
графика»? Нужно ли проводить прием экзамена
по дисциплине «БД» у студента Сидорова
К.Н.? Сколько часов лаб.работ необходимо
провести со студентом Петровым В.С. по
дисциплине «БД»?
Объекты обладают следующими связями:
- Дисциплины
- Код дисциплины
- Название дисциплины
- Студенты
- Код студента
- Имя студента
- Форма обучения
- Год поступления
- Преподаватели
- Код преподавателя
- Имя преподавателя
- Учебные ланы
- Код плана
- Название плана
- Год утверждеиия
- Продолжительность обучения
- Студент-План
- Код студента
- Код плана
Студент
может иметь только один учебный план,
а план может иметь неограниченное количество
студентов.
Студент
Учебный план
Дисциплина-преподаватель
- Код предмета
- Код преподавателя
У дисциплины может быть только один преподаватель, а преподаватель может преподавать несколько дисциплин.
Дисциплина
Преподаватель
- Дисциплина-План
- Код дисциплины
- Код плана
- Курс
- Лекции
- Лаб.работы
- Практики
- Зачёт
- Экзамен
У учебного
плана может быть до шести
одинаковых дисциплин (в
Учебные планы
Дисциплины
Физическая модель данных (макеты таблиц)
Объекты обладают следующими связями:
- Дисциплины
| Disciplina | |
| Код | Название |
| ID_disc* | a_ disc |
| I | A(20) |
- Студенты
| Student | |||
| Код | ФИО | Форма обуч. | Год поступления |
| ID_stud* | a_stud | b_stud | year_stud |
| I | A(30) | A(5) | I |
- Преподаватели
| Prepodavatel | |
| Код | ФИО |
| ID_prep* | а_prep |
| I | A(30) |
- Учебные планы
| Plan | |||
| Код | Название | Год | Продолжит. обуч. |
| ID_plan* | b_plan | year_plan | prod_year |
| I | A(30) | I | I |
- Студент-План
| Inf_Stud | |
| Код студента | Код плана |
| ID_stud* | ID_plan |
| I | I |
- Дисциплина-Преподаватель
| Inf_Disc | |
| Код дисциплины | Код преподавателя |
| ID_disc * | ID_prep |
| I | I |
- Дисциплина-Преподаватель
| Inf_Plan | |||||||
| Код
дисциплины |
Код
плана |
Курс | Лекц. | Лаб. | Практ. | Зачёт | Экзамен |
| ID_disc * | ID_prep* | kurs | lec | labs | prakt | zach | exam |
| I | I | I | I | I | I | I | I |
список явных ограничений целостности
- Не может быть больше одной дисциплины с одинаковым названием.
- Не может быть двух и более одинаковых учебных планов.
- Не может быть удалён студент, для которого определён учебный план. При удалении студента необходимо удалять связанные поля в таблице «Студент-План».
- При удалении дисциплины необходимо удалять также связанные поля в таблице «Дисциплина-Преподаватель» и «Дисциплина-План».
- При удалении учебного плана необходимо также удалять связанные поля в таблице «Дисциплина-План» и «Студент-План».
- При удалении преподавателя необходимо также удалять связанные поля в таблице «Дисциплина-Преподаватель».
- Нельзя добавлять связи для несуществующих студентов, преподавателей, планов и дисциплин.
функции и процедуры
Основной
класс MainWindow отвечает за соединение с
базой данных, а также за правильное
отображение, редактирование и поиск
данных. Пять зависимых класса визуально
облегчают представление и редактирование
данных. Основной класс содержит главные
функции и процедуры для работы с базой.
Соединение с базой выполняется следующим образом:
db=QSqlDatabase::addDatabase("
db.setDatabaseName("baza.db ");
db.open();
Отображение таблиц:
//Вывод таблицы Disciplina
Disciplina=new QSqlTableModel(0,db);
Disciplina->setTable("
Disciplina->select();
Disciplina->setEditStrategy(
ui->disc_viev->setModel(
ui->disc_viev->
//Вывод таблицы Prepodavatel
Prepodavatel=new QSqlTableModel(0,db);
Prepodavatel->setTable("
Prepodavatel->select();
Prepodavatel->
ui->prep_viev->setModel(