Автор: Пользователь скрыл имя, 23 Августа 2011 в 11:58, курсовая работа
На сегодняшний день существует множество различных систем управления базами данных. Они все используют разные средства и функции, но преимущественно у всех СУБД в основе лежат одинаковые понятия. Поэтому для обобщения этих понятий, приемов и методов на весь класс СУБД, я хотела бы взять программу, входящую в Microsoft Office, Microsoft Access.
I. Введение ........................................................................................................5
II. 1.Создание базы данных ..............................................................................6
1.1 Этапы проектирования базы данных ..................................................6
1.Определение цели создания базы данных.............................................6
2.Определение таблиц, которые должна содержать база данных.......6
3.Присвоение ключевых полей .................................................................7
4.Редактирование структуры базы данных.............................................7
5.Добавление данных и создание других объектов базы данных........7
1.2 Инфологическая модель.......................................................................8
2. Даталогическая модель.............................................................................10
2.1 Структура моей базы данных. Таблицы ...........................................10
2.2 Нормализация .....................................................................................13
2.3 Схема данных ......................................................................................14
3. Создание пользовательского интерфейса ..............................................16
3.1 Запросы ................................................................................................16
3.2 Формы ..................................................................................................25
3.3 Отчеты ..................................................................................................29
3.4 Макросы ...............................................................................................31
4.Основной интерфейс базы данных ...........................................................32
III. Заключение...................................
3. Создание пользовательского интерфейса
3.1 Запросы
В моей БД содержатся 14 запросов всех типов:
Ниже я опишу каждый из запросов.
Запрос «Все клиенты»
Данный запрос при выполнении дает информацию обо всех клиентах организации – название фирмы, адрес, телефон и e-mail.
Данные для этого запроса берутся из таблицы Клиенты.
В режиме SQL запрос выглядит так:
SELECT Клиенты.Фирма,
Клиенты.Адрес, Клиенты.
FROM Клиенты;
Запрос «Выборка по ценам типа товаров»
Данный запрос группирует все записи в таблице Товар по типу товаров и выводит :
При выполнении запрос выглядит так:
Данные для создания запроса берутся из таблицы Товар, а для подсчета максимальной и минимальных цен в режиме SQL вводим данные и с помощью Sum выводятся нужные нам цены.
В режиме SQL запрос выглядит так:
SELECT Товар.Тип, Min(Товар.Цена) AS [Минимальная Цена], Max(Товар.Цена) AS [Максимальная Цена], Sum(Товар.Количество) AS [Общее Кол-во]
FROM Товар
GROUP BY Товар.Тип;
Запрос «Добавление заказа»
Данный запрос добавляет заказы в таблицу Выполненные заказы невыполненные в таблице Заказы. Запрос вносит в эту таблицу следующие данные ФИО клиента, Код заказа и Дату заказа, которые он берет из таблицы Заказы. Этот запрос проверяет, является поле Выполнен (в таблице Заказы) ложным или нет. Если да, то он берет эти данные, и подставляет в таблицу Выполненные заказы. Также в эту таблицу
вставляются данные о том, когда был выполнен заказ, количество товаров, заказанное данным клиентом и сумму покупки.
В режиме SQL запрос выглядит так:
INSERT INTO [Выполненные заказы] ( [Код заказа], Фирма, [Дата заказа], [Дата выполнения], Количество, [Сумма заказа] )
SELECT Заказы.[Код
заказа], Заказы.Фирма, Заказы.[Дата
заказа], Date() AS [Дата выполнения], Sum(Товар.Количество)
AS Количество, Sum(Заказанные_товары!
FROM Заказы INNER JOIN (Товар INNER JOIN Заказанные_товары ON Товар.Номер = Заказанные_товары.[Код товара]) ON Заказы.[Код заказа] = Заказанные_товары.Номер
GROUP BY Заказы.[Код заказа], Заказы.Фирма, Заказы.[Дата заказа], Date(), Заказы.Выполнен
HAVING (((Заказы.Выполнен)=False));
Запрос «Заказанные_товары и клиенты»
Данный запрос при выполнении выводит все заказанные товары, название фирмы – клиента, которая заказала товар, требуемое количество товара и его цену, а также дату поступления заказа на данный товар. Выборка осуществляется только по тем товарам, которые были заказаны хотя бы один раз. А данные для этого запроса находятся в таблицах Заказанные_товары, Клиенты и Товар.
В режиме SQL запрос выглядит так:
SELECT Заказы.Фирма,
Товар.Тип, Товар.
FROM (Клиенты
INNER JOIN Заказы ON Клиенты.Фирма=Заказы.Фирма)
INNER JOIN (Товар INNER JOIN Заказанные_товары
ON Товар.Номер=Заказанные_товары.
«Запрос на Выборку всех клиентов с введенной буквы».
При запуске этого запроса он требует ввести букву или несколько букв, с которых начинается название фирмы – клиента (данные из таблицы Клиенты). Данный запрос довольно прост, но необходим. Например если продавец помнит первую букву или несколько букв, то он запускает данный запрос и вводит, ту букву, которую помнит, а в ответ на введенную букву запрос выводит название всех фирм на указанную букву.
В режиме SQL данный запрос выглядит так :
SELECT Клиенты.Фирма, Клиенты.Адрес, Клиенты.Телефон
FROM Клиенты
WHERE (((Клиенты.Фирма)
Like [Введите] & "*"));
«Запрос по типу товара»
Простой запрос, который позволяет выводить товары (из таблицы Товар) по определенному типу. При этом дается описание товара – производитель, характеристика, цена, количество.
Ниже представлен результат выполнения данного запроса при введении товара «Шубы» :
В режиме SQL запрос выглядит так:
SELECT Товар.Тип,
Товар.Производитель, Товар.
FROM Товар
WHERE (((Товар.Тип)
Like [Введите тип] & "*"));
Запрос на обновление «Обновление заказа».
Запрос, который
обновляет количество товаров (в
том числе и проданных) в таблице
Товар, а также он обновляет поле Выполнен
в таблице Заказы. Запрос работает
следующим образом: если в таблице Заказы
в поле Выполнен есть заказы с ложным
значением (False), то данный запрос обновляет
все товары, которые содержатся в данном
заказе в таблице Товар.
Например
: В таблице Заказы есть заказ, состоящий
из 5 товаров «Шорты, мини», содержащий
название фирмы-заказчика и дату заказа.
Данный заказ не выполнен, т.е. в поле
Выполнен стоит значение ложь. Запустив
запрос «Обновление
заказа», происходит следующее: значение
выполнен в таблице становится истиной
(True), количество имеющихся на складе
товаров «Шорты, мини» уменьшается на
5, в то время как количество проданных
на столько же увеличивается.
В режиме SQL запрос выглядит так:
UPDATE
Заказы INNER JOIN (Товар INNER JOIN Заказанные_товары
ON (Товар.Номер = Заказанные_товары.[Код
товара]) AND (Товар.Номер = Заказанные_товары.[Код
товара])) ON Заказы.[Код заказа] = Заказанные_товары.Номер
SET Товар.Количество = Товар.Количество-Заказанные_
WHERE
(((Заказы.Выполнен)=False));
Запрос на «Создание таблицы уцененных товаров».
Этот запрос создает новую таблицу с уцененными товарами. Он работает следующим образом :
При запуске запроса необходимо ввести процент уценения товаров, а затем дату. Запрос выбирает все товары, дата поставки которых соответствует введенной дате, и копирует их в новую таблицу Уцененные товары.
Например :
Я запускаю запрос и ввожу процент = 15
и дату 07.01.05. В итоге у меня получается таблица, содержащая 2 записи:
По сравнению с таблицей Товар цены действительно снизились на 15%.
В режиме SQL запрос выглядит так:
SELECT
Товар.Тип, Товар.
FROM Товар
WHERE (((Товар.[Дата
поставки])=[Введите
дату]));
Запрос «Сумма всех товаров»
Этот запрос
позволяет определить, сколько
на складе товара каждого типа и
его цену, а также общую стоимость всей
партии каждого товара. Все данные для
запроса из таблицы Товар. Я считаю этот
запрос полезным, так как с его помощью
можно определить общую стоимость всех
имеющихся
товаров. Чтобы посчитать сумму всех товаров, надо в режиме SQL умножить цену всех товаров на их количество.
(сортировка по типу)
В режиме SQL запрос выглядит так:
SELECT
Товар.Тип, Товар.
FROM
Товар;Запрос на добавление;
Запрос «Сумма покупок клиентов»
Запрос выбирает всех клиентов, совершивших заказ, и выдает информацию о сумме заказа, о количестве заказанных товаров и о выполнении заказа.
Данный
запрос необходим для определения
частых клиентов и для рассмотрения возможности
предоставления льгот и скидок постоянным
заказчикам. Для построения запроса данные
берутся из таблиц Заказы, Заказанные
товары, Клиенты, Товар.
В режиме SQL запрос выглядит так:
SELECT Заказы.Фирма,
Заказы.[Дата заказа], Sum(Заказанные_товары.
FROM (Клиенты
INNER JOIN Заказы ON Клиенты.Фирма=Заказы.Фирма)
INNER JOIN (Товар INNER JOIN Заказанные_товары
ON Товар.Номер=Заказанные_товары.
GROUP BY Заказы.Фирма,
Заказы.[Дата заказа], Заказы.Выполнен;
«Товар, цена которого больше заданной»
Запрос, позволяющий выбирать товары с наибольшей стоимостью. В запросе выводятся товары (таблица Товар), у которых цена выше заданной суммы.
Я ввела сумму 14200 и получила результат:
В режиме SQL запрос выглядит так:
SELECT Товар.Тип,
Товар.Производитель, Товар.
FROM Товар
WHERE (((Товар.Цена)=[введите
цену] Or (Товар.Цена)>[введите цену]));
Запрос на «Товары с высокой стоимостью»
Запрос делает выборку из таблицы Товар по стоимости товаров и выдает информацию о 10 наиболее дорогостоящих.
При построении
запроса я использовала в режиме
SQL предикат TOP10 – вывод на экран первые
10 товаров (без повторения). Помимо цен
и самих товаров, прилагается еще характеристика
товара и его фирма- производитель.
В режиме SQL запрос выглядит так:
SELECT TOP
10 Товар.Тип, Товар.
FROM Товар
ORDER BY Товар.Цена
DESC;
Запрос на «Удаление Поставщика»
Данный запрос
очень прост, но полезен. Он позволяет
удалять из базы производителя, с
которым мы больше не работаем, не открывая
таблицы Производитель_товара.
В режиме SQL запрос выглядит так:
DELETE Поставщик_товара.Поставщик, Поставщик_товара.Поставщик
FROM Поставщик_товара
WHERE (((Поставщик_товара.Поставщик)
Формы создавать достаточно просто. Для этого в режиме «мастер форм» выбираются значения из таблиц и формируются по усмотрению разработчика базы.
Моя База Данных содержит 11 форм:
Форма «Все заказы».
Простая форма, выводящая все заказы, как выполненные, так и невыполненные.
Информация о работе Разработка базы данных торговой организации