Автор работы: Пользователь скрыл имя, 26 Марта 2013 в 14:52, курсовая работа
Магазин занимается продажей компьютерных дисков с играми через интернет с помощью платежной системы «WebMoney» с возможностью доставки покупателю наземной почтой, курьером или авиапочтой (каждый вид доставки имеет свою стоимость и скидки). Каждый покупатель имеет собственный аккаунт, где хранятся его ФИО, логин, пароль, адрес электронной почты, полный домашний адрес, номер счета WebMoney», размер накопительной скидки и контактный телефон. У каждого покупателя есть счета (номера счетов), которые содержат информацию о способе, стоимости и дате отправки купленного покупателем товара, а также скидку на доставку. У каждой продажи есть свой уникальный номер
1. Цель выполнения курсового проекта. 4
2. Анализ предметной области. 4
2.1 Описание предметной области. 4
2.2 Ограничения, присутствующие в предметной области. 5
2.3 Основные задачи, решаемые в предметной области. 5
3. Проектирование инфологической модели данных. 5
3.1 Первая нормальная форма. 6
3.2 Вторая нормальная форма. 6
3.3 Третья нормальная форма. 8
3.4 Четвертая нормальная форма. 9
3.5 Описание основных сущностей и их атрибутов. 10
3.6 Выявление связей между сущностями 13
3.7 Инфологическая модель данных в нотации Чена. 13
4. Концептуальная модель 15
4.1 Логический уровень модели данных. 15
4.2 Физический уровень модели данных. 16
4.3 Сгенерированный в ERwin SQL код таблиц. 20
5. Проектирование представлений, последовательностей, триггеров, хранимых процедур. 23
5.1 Последовательности. 23
5.2 Триггеры. 23
5.3 Представления. 25
5.4 Хранимые процедуры. 26
6. Реализация базы данных в среде серверной СУБД PostgreSQL 8.4. 28
6.1 Представления. 28
6.2 Триггеры. 29
6.3 Хранимые процедуры. 33
7. Разработка клиент-серверного приложения. 42
7.1 Руководство пользователя. 43
7.1.1 Регистрация. 43
7.1.2 Поиск. 43
7.1.3 Авторизация и деавторизация. 44
7.1.4 Возможности для покупателей. 44
7.1.5 Возможности для продавцов. 46
7.1.6 Возможности для администратора. 47
7.2 Листинг программы. 48
7.2.1 Регистрация нового покупателя. 48
7.2.2 Редактирование профиля покупателя. 49
7.2.3 Вывод на экран истории заказов клиента. 50
8. Заключение. 52
9. Список литературы. 53
FROM goods g WHERE ( (lower(g.name) LIKE lower('%' || whattofind || '%')) or
(lower(g.developer) LIKE lower('%' || whattofind || '%')) or (lower(g.publisher) LIKE lower('%' || whattofind || '%')) ) AND (g.count_at_storehouse<>0) LOOP
RETURN NEXT;
END LOOP;
END;
$body$
LANGUAGE 'plpgsql'
VOLATILE
CALLED ON NULL INPUT
SECURITY INVOKER
COST 100 ROWS 1000;
Результат работы:
CREATE OR REPLACE FUNCTION "public"."TopGood" (out "NameOfGood" varchar, out "SellingCount" integer) RETURNS record AS
$body$
DECLARE
g_id INTEGER;
gname VARCHAR;
cnt INTEGER;
cntSumm INTEGER;
BEGIN
"SellingCount":=0;
FOR g_id, gname IN SELECT g.goods_id, g.name FROM goods g LOOP
cntSumm:=0;
FOR cnt IN SELECT r.reteil_count FROM reteil r WHERE (r.goods_id=g_id) LOOP
cntSumm:=cntSumm+cnt;
END LOOP;
IF cntSumm>"SellingCount" THEN
"SellingCount":=cntSumm;
"NameOfGood":=gname;
END IF;
END LOOP;
END;
$body$
LANGUAGE 'plpgsql'
VOLATILE
CALLED ON NULL INPUT
SECURITY INVOKER
COST 100;
Результат работы:
CREATE OR REPLACE FUNCTION "public"."Top_Seller" (out "Name" varchar, out "Selled" integer) RETURNS record AS
$body$
DECLARE
id_s INTEGER;
cnt INTEGER;
sname VARCHAR;
BEGIN
"Selled":=0;
FOR id_s, sname IN SELECT ss.employee_id, ss.last_name FROM shop_staff ss LOOP
SELECT INTO cnt COUNT(a.account_id) FROM accounts a WHERE (a.employee_id=id_s);
IF cnt>"Selled" THEN
"Selled":=cnt;
"Name":=sname;
END IF;
END LOOP;
END;
$body$
LANGUAGE 'plpgsql'
VOLATILE
CALLED ON NULL INPUT
SECURITY INVOKER
COST 100;
Результат работы:
Для более удобной работы с базой данных, было разработано клиент-серверное web-приложение на языке высокого уровня Java, в котором в качестве клиента используется браузер, а в качестве сервера приложений – сервлет-контейнер Apache Tomcat 6.0, который связан с серверной частью СУБД PostgreSQL.
При разработке приложения были использованы технологии: JDBC, XML, JSP и Ajax (JQuery), а также паттерны: MVC, Command Factory, Singlton и Object Pool.
Подключение всех пользователей к БД осуществляется с полными правами к БД, а разграничение доступа для разных пользователей реализовано на уровне приложения (ограничение использования паттерна Object Pool).
Возможности приложения:
Рисунок 7.1. Главная страница разработанного web-приложения.
7.1 Руководство пользователя.
7.1.1 Регистрация.
Незарегистрированные пользователи имеют доступ к функции регистрации и поиска товара.
Для регистрации нового пользователя, пройдите по ссылке «Регистрация» и заполните все поля, затем нажмите на кнопку «Зарегистрироваться» – рис. 7.1. В случае успешной регистрации, Вы сможете войти на сайт под своим логином и паролем.
Рисунок 7.1. Регистрация нового пользователя.
7.1.2 Поиск.
Поиск по каталогу товаров может осуществлять любой пользователь магазина. Для осуществления поиска введите в соответствующее поле ввода искомый текст и нажмите на кнопку «Искать» - рис. 7.2. Если в поле ввода текста ничего не ввести и нажать на кнопку «Искать», то будет выведен на экран весь список товаров в каталоге, которые есть в наличии на текущий день.
Рисунок 7.2. Поиск товара.
7.1.3 Авторизация и деавторизация.
Если Вы являетесь зарегистрированным пользователем, то для авторизации введите свой логии и пароль в соответствующие поля и нажмите «Войти» - рис. 7.3.
Рисунок 7.3. Авторизация.
Для деавторизации достаточно нажать на кнопку «Выйти», которая появляется, после успешной авторизации на месте полей ввода логина и пароля – рис. 7.4.
Рисунок 7.4. Деавторизация.
В случае успешной
авторизации, в зависимости от Вашей
роли в магазине (покупатель, продавец,
администратор), смотрите соответствующий
раздел данного руководства
7.1.4 Возможности для покупателей.
Покупатель
может выполнять следующие
Для просмотра истории своих заказов, нажмите на соответствующую кнопку в меню покупателя – рис. 7.5.
Рисунок 7.5. Меню покупателя.
Пример истории заказов представлен на рисунке 7.6.
Рисунок 7.6. Пример истории заказов.
Для редактирования своего профиля, нажмите на соответствующую кнопку в меню покупателя – рис. 7.5. Вы увидите ваши регистрационные данные с возможностью их изменить. Для сохранения результатов нажмите на кнопку «Сохранить изменения» - рис. 7.7.
Рисунок 7.7. Редактирование профиля.
Чтобы совершить покупку, с помощью функции поиска (раздел 7.1.2) найдите интересующий Вас товар, а затем в колонке «Купить» нажмите на ссылку с изображением корзины напротив интересующего Вас товара – рис 7.8.
Рисунок 7.8. Осуществление покупки.
После перехода по ссылке Вы увидите страницу оформления заказа, где можете ввести количество покупаемого товара – рис. 7.9. Для осуществления покупки нажмите на кнопку «Купить».
Рисунок 7.9. Страница оформления заказа.
7.1.5 Возможности для продавцов.
Продавец с помощью меню продавца может выполнять следующие действия: добавлять в каталог новые товары, а также узнавать о невостребованном товаре в каталоге магазина (товар, который не продавался больше месяца) – рис. 7.10.
Рисунок 7.10. Меню продавца.
Чтобы добавить новый товар, нажмите на кнопку «Добавить новый товар», а затем после перехода на страницу добавления товара, заполните все поля и нажмите на кнопку «Добавить товар» - рис. 7.11.
Рисунок 7.11. Страница добавления нового товара.
Чтобы посмотреть невостребованный товар, нажмите на соответствующую кнопку в меню продавца – рис. 7.10.
Пример результата поиска невостребованного товара представлен на рисунке 7.12.
Рисунок 7.12. Пример результата поиска невостребованного товара.
7.1.6 Возможности для администратора.
Администратор
может выполнять следующие
Рисунок 7.13. Меню администратора.
Для просмотра зарплаты сотрудников, нажмите на соответствующую кнопку в меню администратора.
Пример отчета по зарплате сотрудников представлен на рисунке 7.14.
Рисунок 7.14. Пример отчета по зарплате сотрудников.
В данном разделе представлены части листинга приложения, отвечающие за основные функции работы с СУБД PostgreSQL 8.4. Остальные функции приложения, связанные с работой с СУБД, реализованы аналогично ниже представленным.
7.2.1 Регистрация нового покупателя.
public class Registration implements Command {
public void execute(HttpServletRequest request, HttpServletResponse response, ServletContext sc, HttpSession session) throws IOException {
String s = "";
Connection c = ((JDBCConnectionPool) sc.getAttribute("ConPool")).
String login = request.getParameter("Rlogin")
String pass = request.getParameter("Rpass");
String cpass = request.getParameter("RCpass")
String email = request.getParameter("email");
String lastname = request.getParameter("
String firstname = request.getParameter("
String thirdname = request.getParameter("
String webmoney = request.getParameter("
String address = request.getParameter("
String phone = request.getParameter("Rphone")
if (!phone.equals("") && !cpass.equals("") && !email.equals("") && !login.equals("") && !pass.equals("") && !lastname.equals("") && !firstname.equals("") && !thirdname.equals("") && !webmoney.equals("") && !address.equals("")){
try {
Statement stmt = c.createStatement();
stmt.executeUpdate("INSERT INTO buyers (last_name,first_name,third_
"VALUES ('" + lastname + "','" + firstname + "','" + thirdname + "','" + login + "','" + pass + "','" + email + "','" + webmoney + "','" + address + "','" + phone + "');");
s = "Регистрация прошла успешно. Теперь Вы можете войти на сайт под своим логином и паролем.";
} catch (SQLException e) {
s = "К сожалению регистрация невозможна!";
}
}else
s = "<center><h3>Заполенены не все поля!</h3><p><p>
<a href=\"javascript:history.go(-
request.setAttribute("answer", s);
RequestDispatcher dispatcher = sc.getRequestDispatcher("/
try {
dispatcher.forward(request, response);
} catch (ServletException e) {
e.printStackTrace();
}
((JDBCConnectionPool) sc.getAttribute("ConPool")).
}
}
7.2.2 Редактирование профиля покупателя.
public class EditBuyerProfile implements Command {
public void execute(HttpServletRequest request, HttpServletResponse response, ServletContext sc, HttpSession session) throws IOException {
String s = "";
Connection c = ((JDBCConnectionPool) sc.getAttribute("ConPool")).
String login = request.getParameter("Rlogin")
String pass = request.getParameter("Rpass");
String email = request.getParameter("email");
String lastname = request.getParameter("
String firstname = request.getParameter("
String cpass = request.getParameter("RCpass")
String thirdname = request.getParameter("
String webmoney = request.getParameter("
String address = request.getParameter("
String phone = request.getParameter("Rphone")
int b_id = (Integer) session.getAttribute("id");
if (session.getAttribute("role") != null)
request.setAttribute("succ", true);
if (!phone.equals("") && !cpass.equals("") && !email.equals("") && !login.equals("") && !pass.equals("") && !lastname.equals("") && !firstname.equals("") && !thirdname.equals("")
&& !webmoney.equals("") && !address.equals("")) {
try {
Statement stmt = c.createStatement();
stmt.executeUpdate("UPDATE buyers SET last_name='" + lastname + "',first_name='" + firstname + "',third_name='" + thirdname + "',login='" + login + "', password='" + pass + "', email='" + email + "', webmoney_account_number='" + webmoney + "',home_address='" + address + "', phone='" + phone + "' " +
" WHERE buyers.buyer_id=" + b_id + ";");
s = "Данные успешно изменены!";
} catch (SQLException e) {
s = "<center><h3>К сожалению данные изменить
невозможно!</h3><p><p> <a href=\"javascript:history.go(-
}
} else
s = "<center><h3>Заполенены не все поля!</h3><p><p>
<a href=\"javascript:history.go(-
request.setAttribute("answer", s);
RequestDispatcher dispatcher = sc.getRequestDispatcher("/
try {
dispatcher.forward(request, response);
} catch (ServletException e) {
e.printStackTrace();
}
((JDBCConnectionPool) sc.getAttribute("ConPool")).
}
}
7.2.3 Вывод на экран истории заказов клиента.
public class OrdersHistory implements Command {
public void execute(HttpServletRequest request, HttpServletResponse response, ServletContext sc, HttpSession session) throws IOException {
String s = "";
try {
Connection c = ((JDBCConnectionPool) sc.getAttribute("ConPool")).
Statement stmt = c.createStatement();
s = FindBadGoods(stmt, session);
((JDBCConnectionPool) sc.getAttribute("ConPool")).
} catch (SQLException e) {
e.printStackTrace();
}
if (session.getAttribute("role") != null)
request.setAttribute("succ", true);
request.setAttribute("search", s);
RequestDispatcher dispatcher = sc.getRequestDispatcher("/
try {
dispatcher.forward(request, response);
} catch (ServletException e) {
e.printStackTrace();
}
}
private String FindBadGoods(Statement stmt, HttpSession session) {
ResultSet rs;
String Name;
int Count;
Date DateOfReteil;
StringBuffer sb = new StringBuffer();
Integer b_id;
b_id = (Integer) session.getAttribute("id");
if (b_id != null && (session.getAttribute("role").
sb.append("<table border=\"1\">\n" +
Информация о работе Проектирование и реализация базы данных «On-line магазин»