Курсовая работа: Программа Футбольный болельщик
Название: Программа Футбольный болельщик Раздел: Рефераты по информатике Тип: курсовая работа | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
МИНИСТЕРСТВО ОБРАЗОВАНИЯ РОССИЙСКОЙ ФЕДЕРАЦИИ Федеральное государственное образовательное учреждение высшего профессионального образования «Чувашский государственный университет им. И.Н. Ульянова» Факультет информатики и вычислительной техники Кафедра «Информационно-вычислительных систем» Дисциплина «Базы данных» Пояснительная записка к курсовой работе Тема: «Футбольный болельщик» Выполнил Проверил Чебоксары – 2009 Содержание 1 Задание 2 Анализ. Предметная область 2.1 Описание предметной области (уточненной у преподавателя) 2.2 Перечень и описание функций приложения обработки базы данны 2.3 Перечень и описание сущностей и атрибутов базы данных 3 Проектирование. Нормализация базы данных. Схема данных 3.1 Пошаговое описание нормализации базы данных (методом ER-диаграмм) 3.2 Схема данных 3.3 Перечень и описание таблиц и их полей (с указанием типов данных и ограничений) в сводной таблице 4 Программная часть. Руководство программиста 4.1 Назначение и условия применения программы 4.2 Характеристика программы 4.3 Обращение к программе 4.4 Входные и выходные данные 4.4.1 Словесное описание 4.4.2 Описание функций 4.5 Сообщения 5 Сопровождение. Руководство пользователя 5.1 Область применения программы 5.2 Краткое описание возможностей 5.3 Уровень подготовки пользователя 5.4 Программные и аппаратные требования к системе 5.5 Подготовка к работе 5.5.1 Состав дистрибутива 5.5.2 Аварийные ситуации 5.5.3 Рекомендации по освоению 6 Список использованной литературы 7 Приложение 1. Исходный текст приложения 1. Задание Футбольный болельщик Написать систему для ведения турнирных таблиц чемпионатов и кубков, в которых участвуют российские команды (чемпионаты как российские, так и международные). Система должна содержать справочную информацию о командах (история, составы, тренеры, игры и победы), игроках (биография, история), тренерах (биография, история, в каких командах играл, если был игроком) и судьях (биография, какие матчи судил, в каких командах играл, если был игроком). В турнирной таблице учитываются очки (3 – за победу, 1 – за ничью, 0 за поражение), а также забитые и пропущенные голы, место проведения. Нужно хранить информацию о каждом матче. 2. Анализ. Предметная область 2.1 Описание предметной области Необходимо разработать информационный ресурс, где хранится информация о футбольных командах, игроках, тренерах, судьях, чемпионатах и матчах. В соответствии с занесенными данными о матче выводить турнирную таблицу и таблицу результатов. 2.2 Перечень и описание функций приложения обработки базы данных 1. Система должна хранить справочную информацию по игрокам, тренерам, командам, судьям, чемпионатам. 2. Система должна регистрировать и хранить информацию о матчах: чемпионат; какая команда играла в гостях, а какая дома; количество забитых и пропущенных голов команды, которая играет дома; дату матча. 3. Система должна выводить турнирную таблицу, в которой хранится информация о количестве игр, количестве забитых и пропущенных мячей, количество побед, проигрышей и ничьих, количество очков. 4. Система должна выводить таблицу результатов(сетку). 5. Система должна осуществлять поиск матчей. 2.3 Перечень и описание сущностей базы данных Игроки. Каждый игрок имеет уникальный номер, ФИО, биографические сведения и амплуа. Команды. За каждой командой закреплен соответствующий код, название, состав и краткие исторические сведения. Тренеры. Каждый тренер имеет уникальный номер , ФИО, биографические сведения. Судьи. Каждый судья имеет уникальный номер, ФИО, биографические сведения. Чемпионаты. Хранится уникальный номер чемпионата, название и год проведения. Матчи. Хранится информация о чемпионате, в рамках которого проводился матч, дата матча, команда, которая играла дома, команда, которая играла в гостях, количество забитых и пропущенных первой командой мячей. 2.4 Перечень и описание всех атрибутов базы данных
3. Проектирование. Нормализация базы данных. Схема данных 3.1 Пошаговое описание нормализации базы данных (методом ERдиаграмм) Нормализуем каждую связь используя соответствующие правила нормализации ER-диаграмм. В результате получим готовую схему данных. 3.2 Схема данных Chempionats (idChemp,NameChemp, Year) Command(idCom, NameCom, AdressCom, Gorod, History, DateSozd, mini_img, big_img) CommandInChemp (idChemp,idCom) Matches(idMatch, idChemp, DateMatch, CityMatch) MatchRezult (idMatch, Doma, Gost, ZabMjach, PropMjach) Players (idPlayer, FPlayer, IPlayer, OPlayer, DateRozhd, Grazhd, BiografPlayer, Amplua) Sostav (idCom, idPlayer, DatePokup, DateProdazh) Sudja (idSud, FSud, ISud, OSud, DateRozhd, Gorod, BiografSud) SudjiInMatch(idMatch, idSud) Treners (idTren, FTren, ITren, OTren, DateRozhd, Gorod, BiografTren) TrenersForCommand (idCom, idTren, DateNaznach, DateUchod) 3.3 Перечень и описание таблиц и их полей в сводной таблице
4. Программная часть. Руководство программиста 4.1 Назначение и условия применения программы Программа предназначена для хранения и вывода данных о командах, игроках, судьях, тренерах, чемпионатах и матчах. Также она генерирует таблицу результатов и турнирную таблицу на основании данных о матче. 4.2 Характеристика программы Программа обладает стандартными временными характеристиками и стандартным режимом работы. 4.3 Обращение к программе Для обращения к программе есть кнопки и выпадающие списки, а так же гиперссылки для удобства перемещения по сайту. 4.4 Входные и выходные данные 4.4.1 Словесное описание Страницы содержат ряд ссылок по которым осуществляется переход на другие страницы <div> <ul> <li><a href="command.php">Команды </a></li> <li><a href="player.php">Игроки </a></li> <li><a href="sudja.php">Судьи </a></li> <li><a href="trener.php">Тренеры </a></li> <li><a href="chempionats.php">Чемпионаты </a></li> Страницы «Команды» (command.php), «Игроки» (player.php), «Судьи» (sudja.php), «Тренеры» (treners.php), «Чемпионаты» (chempionats.php), «Матчи» (match.php), отображаетсоответственносписоккоманд, игроков, судей, тренеров, чемпионатовиматчейвнесенныхвбазу: <?php $zapros = "SELECT * From (Matches INNER JOIN MatchRezult ON Matches.idMatch=MatchRezult.idMatch),Chempionats WHERE Chempionats.idChemp=Matches.idChemp".$wyear.$wchemp; $result = mysql_query($zapros, $db); while ($myrow = mysql_fetch_array($result)) { $doma = $myrow["Doma"]; $res2 = mysql_query("SELECT NameCom FROM MatchRezult, Command WHERE idCom='$doma'"); $row2 = mysql_fetch_array($res2); $gost = $myrow["Gost"]; $res3 = mysql_query("SELECT NameCom FROM MatchRezult, Command WHERE idCom='$gost'"); $row3 = mysql_fetch_array($res3); printf( "<tr> <td> <td> <td> <td> <td> </tr>",$row2[0], $myrow["idMatch"],$myrow["ZabMjach"],$myrow["PropMjach"], $row3[0], $myrow["DateMatch"],$myrow["CityMatch"]); } ?> Страница «Таблица »(table.php) производит подсчет очков, количества игр, разницы между забитыми и пропущенными мячами, количества поражений, побед и ничьих команд в соответствующем чемпионате: <?php $zapros="SELECTID,NameCom, Gorod, sum(igrDoma) igr, sum(zab)-sum(prop) mjach, sum(ochki) ochki,sum(vdoma) vdoma,sum(ndoma) ndoma,sum(pdoma) pdoma,sum(vgost) vgost,sum(ngost) ngost,sum(pgost) pgost, sum(prgost) prgost, sum(zabgost) zabgost, sum(prdoma) prdoma, sum(zabdoma) zabdoma FROM( SELECT Command.idCom as ID, NameCom, Gorod, count(Gost) as igrDoma, PropMjach zab,ZabMjach prop, CASE WHEN PropMjach-ZabMjach>0 THEN '3' WHEN PropMjach-ZabMjach=0 THEN '1' ELSE '0' END ochki, CASE WHEN PropMjach-ZabMjach>0 THEN '1' ELSE '0' END vgost, CASE WHEN PropMjach-ZabMjach=0 THEN '1' ELSE '0' END ngost, CASE WHEN PropMjach-ZabMjach<0 THEN '1' ELSE '0' END pgost,0 vdoma,0 ndoma,0 pdoma, PropMjach zabgost,ZabMjach prgost, 0 prdoma, 0 zabdoma FROM Command, Chempionats, MatchRezult, Matches WHERE NameChemp='Чемпионат России' and Matches.idMatch=MatchRezult.idMatch and Command.idCom=Gost and Matches.idChemp=Chempionats.idChemp".$wyear."GROUP BY MatchRezult.idMatch UNION ALL SELECT Command.idCom as ID, NameCom, Gorod, count(Doma) as igrDoma, ZabMjach zab, PropMjach prop, CASE WHEN PropMjach-ZabMjach<0 THEN '3' WHEN PropMjach-ZabMjach=0 THEN '1' ELSE '0' END ochki, 0,0,0, CASE WHEN PropMjach-ZabMjach<0 THEN '1' ELSE '0' END vgost, CASE WHEN PropMjach-ZabMjach=0 THEN '1' ELSE '0' END ngost, CASE WHEN PropMjach-ZabMjach>0 THEN '1' ELSE '0' END pgost, 0 zabgost, 0 prgost, PropMjach prdoma,ZabMjach zabdoma FROM Command, Chempionats, MatchRezult, Matches WHERE NameChemp='Чемпионат России' and Matches.idMatch=MatchRezult.idMatch and Command.idCom=Doma and Matches.idChemp=Chempionats.idChemp".$wyear."GROUP BY MatchRezult.idMatch ) xxx GROUP BY ID ORDER BY ochki desc"; $result = mysql_query($zapros, $db); $i=1; while($myrow = mysql_fetch_array($result)) { printf(" <tr> <td> <td> <td> <td> <td> <td> <td> <td> <td> <td> <td> <td> <td> <td> <td> <td> </tr>",$i,$myrow['ID'],$myrow['NameCom'],$myrow['Gorod'],$myrow['igr'],$myrow['mjach'],$myrow['ochki'], $myrow['vdoma'], $myrow['ndoma'], $myrow['pdoma'], $myrow['zabdoma'], $myrow['prdoma'], $myrow['vgost'], $myrow['ngost'], $myrow['pgost'], $myrow['zabgost'], $myrow['prgost'] ); $i++; } ?> Страница «Результаты »(resгlt.php) генерирует турнирную сетку в соответствии с результатами матчей: <?php $zapros = "SELECT Command.idCom as ID, NameCom, Gorod FROM Command, Chempionats, CommandInChemp WHERE NameChemp='ЧемпионатРоссии' and Command.idCom=CommandInChemp.idCom and Chempionats.idChemp=CommandInChemp.idChemp".$wyear." GROUP BY Command.idCom"; $result = mysql_query($zapros, $db); $i=1; $k=1; printf(" <tr> <td width='25'> <td width='50'> while ($myrow = mysql_fetch_array($result)) { printf("<td align='center' width='25'> $comarray[$i]=$myrow['ID']; $i++; } printf(" </tr>"); $result = mysql_query($zapros, $db); while($myrow = mysql_fetch_array($result)) { $c=1; $zapis=1; printf(" <tr> <td width='25'> <td> <table width='140' border='0' cellspacing='0' cellpadding='0'> <tr> <td> </tr> <tr> <td> </tr> </table> </td>",$k, $myrow['NameCom'],$myrow['Gorod']); do { if($k==$c) { $c++; } else { $vgost = $myrow["ID"]; $res3 = mysql_query("SELECT Doma, ZabMjach, PropMjach FROM MatchRezult,Matches, Chempionats WHERE Gost='$vgost' and Matches.idMatch=MatchRezult.idMatch and NameChemp='ЧемпионатРоссии' and Chempionats.idChemp=Matches.idChemp".$wyear."ORDER BY Doma "); $row3 = mysql_fetch_array($res3); $vdoma = $row3['Doma']; do { $vdoma = $row3['Doma']; if ($comarray[$c]==$vdoma) { $gostarray[$k][$c]=$row3['PropMjach'].":".$row3['ZabMjach']; $zapis++; } else if($k==$c) { $res3 = mysql_query("SELECT Doma, ZabMjach, PropMjach FROM MatchRezult,Matches, Chempionats WHERE Gost='$vgost' and Matches.idMatch=MatchRezult.idMatch and NameChemp='ЧемпионатРоссии' and Chempionats.idChemp=Matches.idChemp".$wyear."ORDER BY Doma "); for($mas=1;$mas<$c;$mas++) $row3 = mysql_fetch_array($res3); } else { $res3 = mysql_query("SELECT Doma, ZabMjach, PropMjach FROM MatchRezult,Matches, Chempionats WHERE Gost='$vgost' and Matches.idMatch=MatchRezult.idMatch and NameChemp='ЧемпионатРоссии' and Chempionats.idChemp=Matches.idChemp".$wyear."ORDER BY Doma "); for($mas=1;$mas<$zapis;$mas++) $row3 = mysql_fetch_array($res3); } $c++; } while($c<$i && $row3 = mysql_fetch_array($res3)); }//else } while($c<$i); $c=1; $zapis=1; do { if($k==$c) { printf(" <td width='25' bgcolor='#939393'> </td>"); $c++; } else { $doma = $myrow["ID"]; $res2 = mysql_query("SELECT Gost, ZabMjach, PropMjach FROM MatchRezult,Matches, Chempionats WHERE Doma='$doma' and Matches.idMatch=MatchRezult.idMatch and NameChemp='ЧемпионатРоссии' and Chempionats.idChemp=Matches.idChemp".$wyear."ORDER BY Gost "); $row2 = mysql_fetch_array($res2); $gost = $row2['Gost']; if($gost == '') { printf(" <td width='25'> <table width='35' border='0' cellspacing='0' cellpadding='0'> <tr> <td> </tr> <tr> <td> </tr> </table> </td>",$gostarray[$k][$c]); $c++; } else { do { $gost = $row2['Gost']; if ($comarray[$c]==$gost) { printf(" <td width='25'> <table width='35' border='0' cellspacing='0' cellpadding='0'> <tr> <td> </tr> <tr> <td> </tr> </table> </td>",$row2['ZabMjach'],$row2['PropMjach'],$gostarray[$k][$c]); $zapis++; } else if($k==$c) { printf(" <td width='25' bgcolor='#939393'> </td>"); $res2 = mysql_query("SELECT Gost, ZabMjach, PropMjach FROM MatchRezult,Matches, Chempionats WHERE Doma='$doma' and Matches.idMatch=MatchRezult.idMatch and NameChemp='ЧемпионатРоссии' and Chempionats.idChemp=Matches.idChemp".$wyear."ORDER BY Gost "); for($mas=1;$mas<$c;$mas++) $row2 = mysql_fetch_array($res2); } else { printf(" <td width='25'> <table width='35' border='0' cellspacing='0' cellpadding='0'> <tr> <td> </tr> <tr> <td> </tr> </table> </td>",$gostarray[$k][$c]); $res2 = mysql_query("SELECT Gost, ZabMjach, PropMjach FROM MatchRezult,Matches, Chempionats WHERE Doma='$doma' and Matches.idMatch=MatchRezult.idMatch and NameChemp='ЧемпионатРоссии' and Chempionats.idChemp=Matches.idChemp".$wyear."ORDER BY Gost "); for($mas=1;$mas<$zapis;$mas++) $row2 = mysql_fetch_array($res2); } $c++; } while($c<$i && $row2 = mysql_fetch_array($res2)); } }//else } while($c<$i); $k++; printf(" </tr>"); } ?> Также в приложении присутствует администраторская часть, предназначенная для добавления редактирования и удаления данных. Входными данными являются данные, введенные пользователем в соответствующие поля. 4.4.2 Описание функций mysql_connect() – подключение к MySQL; include("bd.php") – подключение к файлу; printf() – вывод информации на экран; mysql_query () – возвращение результата запроса; mysql_fetch_array () – получение результата запроса; echo – вывод информации; 4.5 Сообщения Сообщения выводятся только в администраторской части программы. При неверных действиях пользователей недопустимых значениях входных данных, система выдает пользователю соответствующие сообщения. При успешном завершении действия пользователь тоже получает сообщения об успешном завершении. 5. Сопровождение. Руководство пользователя 5.1. Область применения программы Программа предназначена для хранения информации о футбольных матчах, подсчета данных о командах в турнире, генерации турнирной сетки. 5.2 Краткое описание возможностей Пользователь может вводить и удалять данные о матчах, игроках, судьях, тренерах, чемпионатах, редактировать состав команд, тренерский штаб команды. 5.3 Уровень подготовки пользователя Пользователи системы должны иметь опыт работы с персональным компьютером на базе операционных систем Microsoft Windows и с браузером типа «Opera» или «IE 5» и выше на уровне среднего пользователя и свободно осуществлять базовые операции. 5.4 Программные и аппаратные требования к системе Требования к программному обеспечению: – браузер типа «Opera» или «IE» ; Требования к аппаратному обеспечению: – Серверы БД; – Веб сервер; – ПК пользователей; – ПК администраторов. 5.5 Подготовка к работе 5.5.1 Состав дистрибутива В состав дистрибутива «Футбольный болельщик» входит: - Серверная часть Windows приложения; - Клиентская часть Windows приложения; 5.5.2 Аварийные ситуации При сбое в работе аппаратуры восстановление нормальной работы системы должно производиться после: - перезагрузки операционной системы; - запуска исполняемого файла системы; При ошибках в работе аппаратных средств (кроме носителей данных и программ) восстановление функции системы возлагается на ОС. При ошибках, связанных с программным обеспечением (ОС и драйверы устройств), восстановление работоспособности возлагается на ОС. При неверных действиях пользователей, неверных форматах или недопустимых значениях входных данных, система выдает пользователю соответствующие сообщения, после чего пользователь может пройтись по ссылке на любую страницу, которая будет нормально функционировать. 5.5.3 Рекомендации по освоению Для успешного освоения приложения «Футбольный болельщик» необходимо иметь навыки работы с ПК, базовые знания HTML(для корректного ввода текстовой информации) и изучить следующее: - Настоящее «Руководство пользователя». 6. Список использованной литературы 1. Евгений Попов. PHP и Mysql для начинающих. Видео уроки. 2007. 2. Т.Карпова. Базы данных. Модели, разработка, реализация. «Питер», Санкт-Птербург, 2002. 3. Алексей Гончаров. Самоучитель HTML. 4. www.softtime.ru 7. Приложение 1 Исходный текст приложения bd.php <?php $db = mysql_connect("localhost","root",""); mysql_select_db ("football",$db); ?> left.php <?php include("blocks/bd.php");/* Соединяемся с БД */ ?> <td width="163" valign="top"> <br> <ul> <li><a href="index.php">Главная </a></li> <?php $result = mysql_query("SELECT Year FROM Chempionats ORDER BY Year desc"); $myrow = mysql_fetch_array($result); printf("<li><a href='match.php?year=%s'>Матчи </a></li>",$myrow[0]); ?> <?php $result = mysql_query("SELECT Year FROM Chempionats WHERE NameChemp = 'Чемпионат России' ORDER BY Year desc"); $myrow = mysql_fetch_array($result); printf("<li><a href='result.php?year=%s'>Результат </a></li>",$myrow[0]); ?> <?php $result = mysql_query("SELECT Year FROM Chempionats WHERE NameChemp = 'Чемпионат России' ORDER BY Year desc"); $myrow = mysql_fetch_array($result); printf("<li><a href='table.php?year=%s'>Таблица </a></li>",$myrow[0]); ?> </ul> <div> <ul> <li><a href="command.php">Команды </a></li> <li><a href="player.php">Игроки </a></li> <li><a href="sudja.php">Судьи </a></li> <li><a href="trener.php">Тренеры </a></li> <li><a href="chempionats.php">Чемпионаты </a></li> </ul> <br> </td> match.php <?php include("blocks/bd.php");/* Соединяемся с БД */ $year2=''; $namechemp=''; if(isset($_GET['year'])) {$year = $_GET['year']; $year2="&year=$year"; $wyear=" and Year='$year'";} else {$wyear='';} if(isset($_GET['NameChemp'])) {$chemp = $_GET['NameChemp']; $namechemp="&NameChemp=$chemp"; $wchemp=" and NameChemp='$chemp'";} else {$wchemp='';} ?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=windows-1251" /> <title>Матчи</title> <link href="style.css" rel="stylesheet" type="text/css" /> </head> <body> <table width="900" border="0" align="center" cellpadding="0" cellspacing="0" bgcolor="#FFFFFF"> <!--Шапка сайта--> <? include("blocks/header.php");?> <tr> <td><table width="900" border="0" cellspacing="0" cellpadding="0"> <tr> <!--Левый блок--> <?php include("blocks/left.php");?> <td width="737" valign="top"> <table width="100%" border="0" cellpadding="0" cellspacing="0"> <tr align="right"> <?php printf("<td>Чемпионат <select> <option value='match.php?$year2'>Все чемпионаты"); $result = mysql_query("SELECT NameChemp FROM Chempionats GROUP BY NameChemp", $db); $myrow = mysql_fetch_array($result); do { $s=''; if($_GET['NameChemp'] == $myrow['NameChemp']) $s=" selected='selected'"; printf("<option value='match.php?NameChemp=%s$year2' $s>%s",$myrow['NameChemp'],$myrow['NameChemp']); } while($myrow = mysql_fetch_array($result)); printf("</select></td>"); printf("<td>Год <select> $result = mysql_query("SELECT Year FROM Chempionats GROUP BY Year ORDER BY Year desc", $db); $myrow = mysql_fetch_array($result); do { $s=''; if($_GET['year'] == $myrow['Year']) $s=" selected='selected'"; printf("<option value='match.php?year=%s$namechemp' $s>%s",$myrow['Year'],$myrow['Year']); } while($myrow = mysql_fetch_array($result)); printf("</select></td>"); ?> </tr> </table> <table width="100%" border="0" cellspacing="0" cellpadding="0"> <tr> <td> <td> <td> <td> <td> </tr> <?php $zapros = "SELECT * From (Matches INNER JOIN MatchRezult ON Matches.idMatch=MatchRezult.idMatch),Chempionats WHERE Chempionats.idChemp=Matches.idChemp".$wyear.$wchemp; $result = mysql_query($zapros, $db); while ($myrow = mysql_fetch_array($result)) { $doma = $myrow["Doma"]; $res2 = mysql_query("SELECT NameCom FROM MatchRezult, Command WHERE idCom='$doma'"); $row2 = mysql_fetch_array($res2); $gost = $myrow["Gost"]; $res3 = mysql_query("SELECT NameCom FROM MatchRezult, Command WHERE idCom='$gost'"); $row3 = mysql_fetch_array($res3); printf( "<tr> <td> <td> <td> <td> <td> </tr>",$row2[0], $myrow["idMatch"],$myrow["ZabMjach"],$myrow["PropMjach"], $row3[0], $myrow["DateMatch"],$myrow["CityMatch"]); } ?> </table> </td> </tr> </table></td> </tr> <!--Нижний блок--> <?php include("blocks/footer.php"; ?> |