Банк рефератов содержит более 364 тысяч рефератов, курсовых и дипломных работ, шпаргалок и докладов по различным дисциплинам: истории, психологии, экономике, менеджменту, философии, праву, экологии. А также изложения, сочинения по литературе, отчеты по практике, топики по английскому.
Полнотекстовый поиск
Всего работ:
364150
Теги названий
Разделы
Авиация и космонавтика (304)
Административное право (123)
Арбитражный процесс (23)
Архитектура (113)
Астрология (4)
Астрономия (4814)
Банковское дело (5227)
Безопасность жизнедеятельности (2616)
Биографии (3423)
Биология (4214)
Биология и химия (1518)
Биржевое дело (68)
Ботаника и сельское хоз-во (2836)
Бухгалтерский учет и аудит (8269)
Валютные отношения (50)
Ветеринария (50)
Военная кафедра (762)
ГДЗ (2)
География (5275)
Геодезия (30)
Геология (1222)
Геополитика (43)
Государство и право (20403)
Гражданское право и процесс (465)
Делопроизводство (19)
Деньги и кредит (108)
ЕГЭ (173)
Естествознание (96)
Журналистика (899)
ЗНО (54)
Зоология (34)
Издательское дело и полиграфия (476)
Инвестиции (106)
Иностранный язык (62792)
Информатика (3562)
Информатика, программирование (6444)
Исторические личности (2165)
История (21320)
История техники (766)
Кибернетика (64)
Коммуникации и связь (3145)
Компьютерные науки (60)
Косметология (17)
Краеведение и этнография (588)
Краткое содержание произведений (1000)
Криминалистика (106)
Криминология (48)
Криптология (3)
Кулинария (1167)
Культура и искусство (8485)
Культурология (537)
Литература : зарубежная (2044)
Литература и русский язык (11657)
Логика (532)
Логистика (21)
Маркетинг (7985)
Математика (3721)
Медицина, здоровье (10549)
Медицинские науки (88)
Международное публичное право (58)
Международное частное право (36)
Международные отношения (2257)
Менеджмент (12491)
Металлургия (91)
Москвоведение (797)
Музыка (1338)
Муниципальное право (24)
Налоги, налогообложение (214)
Наука и техника (1141)
Начертательная геометрия (3)
Оккультизм и уфология (8)
Остальные рефераты (21697)
Педагогика (7850)
Политология (3801)
Право (682)
Право, юриспруденция (2881)
Предпринимательство (475)
Прикладные науки (1)
Промышленность, производство (7100)
Психология (8694)
психология, педагогика (4121)
Радиоэлектроника (443)
Реклама (952)
Религия и мифология (2967)
Риторика (23)
Сексология (748)
Социология (4876)
Статистика (95)
Страхование (107)
Строительные науки (7)
Строительство (2004)
Схемотехника (15)
Таможенная система (663)
Теория государства и права (240)
Теория организации (39)
Теплотехника (25)
Технология (624)
Товароведение (16)
Транспорт (2652)
Трудовое право (136)
Туризм (90)
Уголовное право и процесс (406)
Управление (95)
Управленческие науки (24)
Физика (3463)
Физкультура и спорт (4482)
Философия (7216)
Финансовые науки (4592)
Финансы (5386)
Фотография (3)
Химия (2244)
Хозяйственное право (23)
Цифровые устройства (29)
Экологическое право (35)
Экология (4517)
Экономика (20645)
Экономико-математическое моделирование (666)
Экономическая география (119)
Экономическая теория (2573)
Этика (889)
Юриспруденция (288)
Языковедение (148)
Языкознание, филология (1140)

Курсовая работа: Предметная область "тестирование"

Название: Предметная область "тестирование"
Раздел: Рефераты по информатике, программированию
Тип: курсовая работа Добавлен 10:26:37 11 декабря 2010 Похожие работы
Просмотров: 99 Комментариев: 2 Оценило: 0 человек Средний балл: 0 Оценка: неизвестно     Скачать

КУРСОВОЕ ПРОЕКТИРОВАНИЕ

По дисциплине

«Базы данных»

Тема

“Тестирование”

Вариант №7


Содержание

Задание

Результаты анализа предметной области

Описание выполнения этапов проектирования

Концептуальная модель

Описание реляционной модели

Описание реализации запросов

Описание групп пользователей

Описание интерфейса

Описание контрольного пример

Сообщения программы

Тексты программы


Задание. Вариант №7

Предметная область «Тестирование». Возможные виды деятельности: ведение базы вопросов, распределенных по предметам, темам и уровням, и ответов (возможных и правильных) с указанием авторов вопросов; учет выполненного тестирования для каждого обучаемого с информацией о полученных им вопросах, данных ответах и общих результатах; формирование тестов из имеющихся вопросов.

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

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

-деятельности: ведение базы вопросов, распределенных по предметам, темам и уровням, и ответов (возможных и правильных) с указанием авторов вопросов

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

-формирование тестов из имеющихся вопросов.

При этом были сформированы следующие объекты:

-Участник тестирования

-Тест

-Вопрос

-Ответ

-Автор

-Тема

-Уровень

-Предмет


Описание выполненных этапов проектирования БД.

После анализа предметной области указанные ранее объекты были преобразованы в таблицы базы данных.

Таблица-Первичный ключ

Участник-Ид участника

Тест-Ид теста

Вопрос-Ид вопроса

Ответ-Ид ответа

Автор-Ид автора

Тема-Ид темы

Уровень-Ид уровня

Предмет-Ид предмета

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

Так же для создания связей N:M были сформированы таблицы Тест-Вопрос и Вопрос-Ответ.

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


Концептуальная модель данных:

Описание реляционной модели данных

Участник
Поле Описание Тип данных Комментарий
ID_member Ид участника Текстовый Ид участника
FIO ФИО Текстовый ФИО
Passport Паспорт Текстовый Паспортные данные
School Школа Текстовый номер школы
Class Класс Текстовый Номер класса
ID_test Ид теста Текстовый Ид теста
Тест
Поле Описание Тип данных Комментарий
ID_test Ид теста Текстовый Ид теста
Info Информация Текстовый Инф о тесте
Test_data Дата проведения Дата Дата проведения
Location Место проведения Текстовый Место тестирования
Вопрос
Поле Описание Тип данных Комментарий
ID_question Ид вопроса Текстовый Идентификатор
ID_theme Ид темы Текстовый Идентификатор
ID_level Ид уровня Текстовый Идентификатор
ID_subject Ид предмета Текстовый Идентификатор
ID_author Ид автора Текстовый Идентификатор
Q_text Текст Текстовый Сам вопрос(текст)
Ответ
Поле Описание Тип данных Комментарий
ID_answer Ид ответа Текстовый Идентификатор
Grade Оценка Текстовый Оценка за вопрос
Correct Правильность Текстовый Флаг правильности ответа
Ответ-Вопрос
Поле Описание Тип данных
ID_question Ид вопроса Текстовый
ID_answer Ид ответа Текстовый
Тест-Вопрос
Поле Описание Тип данных
ID_test Ид теста Текстовый
ID_question Ид вопроса Текстовый
Предмет
Поле Описание Тип данных
ID_subj Ид предмета Текстовый
Info Данные о предмете Текстовый
Автор
Поле Описание Тип данных
ID_author Ид автора Текстовый
Info Данные об авторе Текстовый
FIO ФИО автора Текстовый
book Данные о книге, из которой был взят вопрос текстовый

Уровень
Поле Описание Тип данных
Код Ид уровня Текстовый
L_text Описание уровня Текстовый
Lvl Номер уровня числовой
Тема
Поле Описание Тип данных
Код Ид темы Текстовый
S_text Описание темы Текстовый

Описание способов реализации запросов и отчётов

Подсчет кол-ва тестов за заданный промежуток времени

SELECT COUNT(ID_test) AS [Kol-vo]

FROM Test

WHERE test_date between x AND y;

Вывод фамилии с поиском по ид теста

SELECT FIO

FROM Member

WHERE ID_test=test;

Вывод оценок ответов в данном тесте

SELECT Answer.grade, Test_Question.ID_test, Test_Question.ID_question, Answer.ID_answer

FROM Answer INNER JOIN (Test_Question INNER JOIN Answer_Question ON Test_Question.ID_question = Answer_Question.ID_question) ON Answer.ID_answer = Answer_Question.ID_answer

WHERE (((Test_Question.ID_test)=[x]) AND ((Test_Question.ID_question)=[Answer_Question].[ID_question]) AND ((Answer.ID_answer)=[Answer_Question].[ID_answer]) AND ((Answer.correct)='yes'));

Поиск участников теста по месту проведения теста

SELECT *

FROM Member

WHERE ID_test=ALL

(SELECT ID_test FROM Test

WHERE location=Gorod);

Поиск вопроса по участку текста вопроса

SELECT *

FROM Question

WHERE Q_text LIKE x+'*';

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

SELECT *

FROM test

WHERE test_date BETWEEN x AND y;

Подсчет кол-ва тестов за прошедшую неделю

SELECT Count(ID_test) AS [kol-vo testov]

FROM Test

WHERE test_date BETWEEN NOW()-7 AND NOW();


Вывод даты проведения теста по ид участника

SELECT test_date

FROM Test AS T INNER JOIN Member AS M ON T.ID_test=M.ID_test

WHERE M.ID_member=member;

Описание групп пользователей ИС, средств управления разделением доступа и функциональных возможностей каждой группы

При реализации продукта было выделено три группы пользователей

Главный администратор:

-возможность просматривать таблицы пользователей и изменять их

-возможность просматривать и изменять все таблицы

-возможность выполнять все вопросы

-возможность просматривать лог действий

Преподователь:

-возможность просматривать и изменять таблицы , связанные с предметной областью

-возможность выполнять все запросы

Ученик:

-возможность просматривать таблицы Вопрос,Тема,Предмет,Автор без изменения их

-возможность выполнения всех запросов

Описание интерфейса ИС

Программа была разработана с использованием одного окна, изменяющего свои размеры в зависимости от этапа работы программы.


1.Окно авторизации при запуске программы:

2.Окно программы при входе под записью главного администратора:


Пример окна после выбора пункта меню-база данных-таблицы-вопросы

Таблица редактируется(изменение уже созданной записи и создание новой здесь же)


Жмем «сохранить» и сохраняем наши изменения в БД

3,При нажатии на пункт меню «запросы» становиться доступным выбор возможных запросов


Пример окна после выбора запроса

Пример запроса с вводом двух данных


4.Просмотр лога действий(базы данных-лог)

Описание контрольного примера

В качестве контрольного примера рассмотрим выполнение запроса на подсчет кол-ва тестов за определенный промежуток времени

1.Входим в систему

2.Выбираем пункт меню «запросы»


3.Выбирем нужный нам запрос

4.Вводим данные и нажимаем «ок»


5.Вводим другой промежуток времени

Сообщения программы, причины, их вызывающие, и реакция пользователя на сообщения

1.Сообщение о неверном вводе логина или пароля


2.Попытка создания записи главного администратора

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

Текст программы, с необходимыми комментариями

Реализация входа пользователя в систему

private: System::Void Вход_Click(System::Object^ sender, System::EventArgs^ e) {

if((textBox1->Text!="") && (textBox2->Text!=""))

{

String^ connect="provider=Microsoft.Jet.OLEDB.4.0;"+path_a;

OleDbConnection^ myOleDbConnection = gcnew OleDbConnection(connect);

OleDbCommand^ myOleDbCommand = myOleDbConnection->CreateCommand();

myOleDbCommand->CommandText =

"Select [id],[lvl]"+

"FROM [auth]"+

"WHERE [login]='"+textBox1->Text+"' AND ([pass]='"+textBox2->Text+"');";

myOleDbConnection->Open();

OleDbDataReader^ myOleDbDataReader = myOleDbCommand->ExecuteReader();

while(myOleDbDataReader->Read())

{

id=Convert::ToInt32(myOleDbDataReader[0]);

lvl=Convert::ToInt32(myOleDbDataReader[1]);

}

myOleDbDataReader->Close();

myOleDbConnection->Close();

}

else

{

this->label3->Visible=true;

}

if(lvl==0)

{

String^ connectionString2 = "provider=Microsoft.Jet.OLEDB.4.0;"+path_a;

OleDbConnection^ myOleDbConnection2 = gcnew OleDbConnection(connectionString2);

OleDbCommand^ myOleDbCommand2 = myOleDbConnection2->CreateCommand();

myOleDbCommand2->CommandText =

"INSERT INTO [log] "+

"VALUES ("+id+", Now(), 'Входвсистему');";

myOleDbConnection2->Open();

OleDbDataReader^ myOleDbDataReader2 = myOleDbCommand2->ExecuteReader();

myOleDbConnection2->Close();

this->Text = L"РаботасБД";

this->ClientSize = System::Drawing::Size(500, 220);

this->menuStrip1->Visible=true;

this->textBox1->Visible=false;

this->textBox2->Visible=false;

this->label1->Visible=false;

this->label2->Visible=false;

this->Вход->Visible=false;

this->Выход->Visible=false;

this->dataGridView1->Visible=true;

this->dataGridView1->Location = System::Drawing::Point(12,30);

this->listBox1->Visible=true;

this->listBox1->Location=System::Drawing::Point(300,30);

}

if(lvl==1)

{

String^ connectionString2 = "provider=Microsoft.Jet.OLEDB.4.0;"+path_a;

OleDbConnection^ myOleDbConnection2 = gcnew OleDbConnection(connectionString2);

OleDbCommand^ myOleDbCommand2 = myOleDbConnection2->CreateCommand();

myOleDbCommand2->CommandText =

"INSERT INTO [log] "+

"VALUES ("+id+", Now(), 'Входвсистему');";

myOleDbConnection2->Open();

OleDbDataReader^ myOleDbDataReader2 = myOleDbCommand2->ExecuteReader();

myOleDbConnection2->Close();

this->Text = L"РаботасБД";

this->ClientSize = System::Drawing::Size(500, 220);

this->menuStrip1->Visible=true;

this->пользователяToolStripMenuItem->Visible=false;

this->участникиToolStripMenuItem->Visible=false;

this->логToolStripMenuItem->Visible=false;

this->textBox1->Visible=false;

this->textBox2->Visible=false;

this->label1->Visible=false;

this->label2->Visible=false;

this->Вход->Visible=false;

this->Выход->Visible=false;

this->dataGridView1->Visible=true;

this->dataGridView1->Location = System::Drawing::Point(12,30);

this->dataGridView1->ReadOnly=false;

this->listBox1->Visible=true;

this->listBox1->Location=System::Drawing::Point(300,30);

this->Сохранить->Enabled=true;

}

if(lvl==2)

{

String^ connectionString2 = "provider=Microsoft.Jet.OLEDB.4.0;"+path_a;

OleDbConnection^ myOleDbConnection2 = gcnew OleDbConnection(connectionString2);

OleDbCommand^ myOleDbCommand2 = myOleDbConnection2->CreateCommand();

myOleDbCommand2->CommandText =

"INSERT INTO [log] "+

"VALUES ("+id+", Now(), 'Входвсистему');";

myOleDbConnection2->Open();

OleDbDataReader^ myOleDbDataReader2 = myOleDbCommand2->ExecuteReader();

myOleDbConnection2->Close();

this->Text = L"РаботасБД";

this->ClientSize = System::Drawing::Size(500, 220);

this->menuStrip1->Visible=true;

this->пользователяToolStripMenuItem->Visible=false;

this->тестВопросToolStripMenuItem->Visible=false;

this->вопросОтветToolStripMenuItem->Visible=false;

this->ответыToolStripMenuItem->Visible=false;

this->участникиToolStripMenuItem->Visible=false;

this->тестыToolStripMenuItem->Visible=false;

this->логToolStripMenuItem->Visible=false;

this->уровеньToolStripMenuItem->Visible=false;

this->textBox1->Visible=false;

this->textBox2->Visible=false;

this->label1->Visible=false;

this->label2->Visible=false;

this->Вход->Visible=false;

this->Выход->Visible=false;

this->dataGridView1->Visible=true;

this->dataGridView1->Location = System::Drawing::Point(12,30);

this->dataGridView1->ReadOnly=true;

this->listBox1->Visible=true;

this->listBox1->Location=System::Drawing::Point(300,30);

this->Сохранить->Enabled=false;

}

}

Участок кода , реализующий один из запросов

if (flag==7)

{

String^ connect="provider=Microsoft.Jet.OLEDB.4.0;"+path_d;

OleDbConnection^ myOleDbConnection = gcnew OleDbConnection(connect);

DataSet = gcnew System::Data::DataSet();

DataSet->CaseSensitive = true;

OleDbCommand^ myOleDbCommand = myOleDbConnection->CreateCommand();

myOleDbCommand->CommandText ="SELECT Answer.grade, Test_Question.ID_test, Test_Question.ID_question, Answer.ID_answer FROM Answer INNER JOIN (Test_Question INNER JOIN Answer_Question ON Test_Question.ID_question = Answer_Question.ID_question) ON Answer.ID_answer = Answer_Question.ID_answer WHERE (((Test_Question.ID_test)='"+this->textBox3->Text+"') AND ((Test_Question.ID_question)=[Answer_Question].[ID_question]) AND ((Answer.ID_answer)=[Answer_Question].[ID_answer]) AND ((Answer.correct)='yes'));";

myOleDbConnection->Open();

myOleDbDataAdapter = gcnew OleDbDataAdapter();

myOleDbDataAdapter->SelectCommand = myOleDbCommand;

myOleDbDataAdapter->Fill(DataSet,"Test");

dataGridView1->DataSource = DataSet ;

dataGridView1->DataMember = "Test";

this->dataGridView1->DataSource = DataSet->Tables["Test"]->DefaultView;

myOleDbConnection->Close();

table="Test";

String^ connectionString2 = "provider=Microsoft.Jet.OLEDB.4.0;"+path_a;

OleDbConnection^ myOleDbConnection2 = gcnew OleDbConnection(connectionString2);

OleDbCommand^ myOleDbCommand2 = myOleDbConnection2->CreateCommand();

myOleDbCommand2->CommandText =

"INSERT INTO [log] "+

"VALUES ("+id+", Now(), 'Выводоценоктестасуказанием id теста');";

myOleDbConnection2->Open();

OleDbDataReader^ myOleDbDataReader2 = myOleDbCommand2->ExecuteReader();

myOleDbConnection2->Close();

}

Так как изменение данных и создание новой записи происходят средствами компонента datagridview то далее будет показан код, отвечающий за сохранение этих данных (кнопка «сохранить»)

private: System::Void Сохранить_Click(System::Object^ sender, System::EventArgs^ e) {

OleDbCommandBuilder^ myOleDbCommandBuilder=gcnew OleDbCommandBuilder(myOleDbDataAdapter);

myOleDbDataAdapter->Update(DataSet,table);

DataSet->AcceptChanges();

String^ connectionString2 = "provider=Microsoft.Jet.OLEDB.4.0;"+path_a;

OleDbConnection^ myOleDbConnection2 = gcnew OleDbConnection(connectionString2);

OleDbCommand^ myOleDbCommand2 = myOleDbConnection2->CreateCommand();

myOleDbCommand2->CommandText =

"INSERT INTO [log] "+

"VALUES ("+id+", Now(), 'Сохранениеизменений');";

myOleDbConnection2->Open();

OleDbDataReader^ myOleDbDataReader2 = myOleDbCommand2->ExecuteReader();

myOleDbConnection2->Close();

}

Оценить/Добавить комментарий
Имя
Оценка
Комментарии:
Где скачать еще рефератов? Здесь: letsdoit777.blogspot.com
Евгений07:39:42 19 марта 2016
Кто еще хочет зарабатывать от 9000 рублей в день "Чистых Денег"? Узнайте как: business1777.blogspot.com ! Cпециально для студентов!
08:12:37 29 ноября 2015

Работы, похожие на Курсовая работа: Предметная область "тестирование"

Назад
Меню
Главная
Рефераты
Благодарности
Опрос
Станете ли вы заказывать работу за деньги, если не найдете ее в Интернете?

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



Результаты(150032)
Комментарии (1830)
Copyright © 2005-2016 BestReferat.ru bestreferat@mail.ru       реклама на сайте

Рейтинг@Mail.ru