|
|
Проектирование реляционных баз данных средствами субд visual dbase 7.0 «Страховая компания»СОДЕРЖАНИЕ ПОСТАНОВКА ЗАДАЧИ 3 1. ПОСТРОЕНИЕ ЛОГИЧЕСКОЙ МОДЕЛИ БАЗЫ ДАННЫХ 4 2. ПОСТРОЕНИЕ ER-ДИАГРАММЫ 6 3. СОЗДАНИЕ СТРУКТУР ТАБЛИЦ 7 4. ВВОД И РЕДАКТИРОВАНИЕ ДАННЫХ В ТАБЛИЦЫ 9 5. ФОРМИРОВАНИЕ ЗАПРОСОВ 11 6. ПРОЕКТИРОВАНИЕ ОТЧЁТОВ 16 7. РАССЫЛКА ПРИГЛАШЕНИЙ 21 ЛИТЕРАТУРА 24 ПОСТАНОВКА ЗАДАЧИ База данных предназначена для использования в страховой компании, которая продаёт страховки различных типов, (клиент может купить одинаковые страховки на разный период времени или одинаковые страховки на разные периоды времени), с целью учёта страховой деятельности и должна предоставлять по запросу следующую информацию: Список клиентов, имеющих страховки одного типа. Перечень страховок одного клиента. Сумму страховок за указанный период времени. Требуется: определить состав информации для хранения в базе данных; спроектировать логическую структуру базы данных методом пошаговой нормализации; обосновать выбор ключевых полей; сформулировать семантические ограничения; построить ER-диаграмму для рассматриваемой предметной области; на основе списка клиентов подготовить к рассылке письма-приглашения на презентацию. 1. ПОСТРОЕНИЕ ЛОГИЧЕСКОЙ МОДЕЛИ БАЗЫ ДАННЫХ В базе данных требуется хранить все сведения о результатах сделок по заключению договоров страхования по разным видам страховки для определённого клиента. Перечислим все возможные элементы данных (поля), составляющие запись о сдаче экзамена: КЛИЕНТ (код клиента, ФИО, адрес, телефон, № договора, код страховки, название страховки, дата заключения, дата окончания, стоимость) Первичным ключом может быть код клиента, так как его значение уникально. Выделим элементы данных, которые могут повторяться для одного студента, то есть они составляют повторяющуюся группу. Обозначим её RG: КЛИЕНТ (код клиента, ФИО, адрес, телефон, RG(№ договора, код страховки, название страховки, дата заключения, дата окончания, стоимость)). Приводим запись к первой нормальной форме, выделив повторяющуюся группу в отдельное отношение под именем ДОГОВОР: 1NF КЛИЕНТ (код клиента, ФИО, адрес, телефон) ДОГОВОР (№ договора, код клиента, код страховки, название страховки, дата заключения, дата окончания, стоимость) Первичный ключ для нового отношения будет составным: код клиента&код страховки Приводим это отношение ко 2-й нормальной форме, то есть проверяем, существует ли зависимость между неключевыми элементами и частью составного ключа). Такая зависимость есть: поле стоимость не зависит от второй части составного ключа - кода клиента). Выделим названные поля в отдельное отношение под названием СТРАХОВКА: 2NF КЛИЕНТ (код клиента, ФИО, адрес, телефон) ДОГОВОР (№ договора, код клиента, код страховки, дата заключения, дата окончания) СТРАХОВКА (код страховки, название страховки, стоимость) Проверяем все отношения на предмет соответствия 3-й нормальной форме, то есть на предмет отсутствия зависимостей между неключевыми элементами. В данном случае таких зависимостей нет: 3NF = 2NF Нормализованная база данных будет содержать 3 таблицы: Клиенты (Client) Договора (Contract) Страховки (Insurance) 2. ПОСТРОЕНИЕ ER-ДИАГРАММЫ 2. СОЗДАНИЕ СТРУКТУР ТАБЛИЦ Изначально предполагаем, что программа Visual dBase запущена и готова к работе, то есть новому проекту присвоено имя и он сохранён в соответствующей папке (каталоге). Для создания таблиц необходимо реализовать проектирование их структуры, для чего в контекстном меню выбираем New - Table и выбираем ручной режим конструирования Designer. Названия (Name) полей (Field) вводим в английском эквиваленте, указываем тип данных (Type), содержащихся в каждом поле (числовые - Numeric, текстовые - Character, календарные - Date и т.п.), а также ограничения на количество знаков в поле (Width). Сохраняем готовую таблицу командой Save As... Таблица соответствия полей № Обозначение Значение 1 CLIENT_CODE код клиента 2 NAME ф.и.о. клиента 3 ADDRESS адрес 4 PHONE телефон 5 CODE номер договора 6 ON_DATE дата заключения 7 OFF_DATE дата завершения 8 INSURANC_CODE код страховки 9 INSURANC_NAME тип страховки 10 COST стоимость страховки В результате проектирования структуры таблиц для решения поставленной задачи получено: Структура таблицы Клиенты (Clients) Clients.dbf - Table Designer Поле Field Имя Name Тип Type Длина Width Свойства Decimal Примечание Index 1 CLIENT_CODE Numeric 10 0 Ascend 2 NAME Character 30 0 None 3 ADDRESS Character 50 0 None 4 PHONE Character 10 0 None В качестве ключевого назначаем поле CLIENT_CODE (код клиента), так значения его в данной таблице должно оставаться уникальным. Структура таблицы Договора (Contract) Contract.dbf - Table Designer Поле Field Имя Name Тип Type Длина Width Свойства Decimal Примечание Index 1 CODE Numeric 10 0 Ascend 2 CLIENT_CODE Numeric 10 0 None 3 INSURANC_CODE Numeric 6 0 None 4 ON_DATE Date 0 None 5 OFF_DATE Date 0 None В качестве ключевого назначаем поле CODE (номер договора), так значения его в данной таблице должно оставаться уникальным. Структура таблицы Страховки (Insurance) Insurance.dbf - Table Designer Поле Field Имя Name Тип Type Длина Width Свойства Decimal Примечание Index 1 INSURANC_CODE Numeric 6 0 Ascend 2 INSURANC_NAME Character 30 0 None 3 COST Numeric 10 0 None В качестве ключевого назначаем поле INSURANC_CODE (код страховки), так значения его в данной таблице должно оставаться уникальным для каждого вида страховки. Следует отметить также дополнительные условия: Каждая страховка одного и того же клиента физически является отдельным договором. Клиент может купить разные страховки на один период времени и одинаковые страховки на разный период. Поля, содержащие календарные данные должны заполняться с соблюдением формата даты по установленной маске. Дата заключения страхового договора не может предшествовать его завершению. 4. ВВОД И РЕДАКТИРОВАНИЕ ДАННЫХ В ТАБЛИЦЫ Для наполнения таблиц данными необходимо перейти из режима проектирования (Table Design) в режим выполнения (Run) и нажать кнопку Добавить записи. При обнаружении ошибок в проектировании структуры таблицы допустимо возвратиться в режим проектирования и осуществить "горячую" корректировку структуры или ограничений. После заполнения таблиц получим следующее: Содержание таблицы Клиенты (Clients) Client.dbf - Table CLIENT_CODE NAME ADDRESS PHONE 1 Климов Алексей Иванович пр-кт Вернадского, 182, кв. 126 405-64-75 2 Аксёнов Сергей Евгеньевич Хамовнический вал, 25, кв. 74 172-58-69 3 Дудкин Степан Юрьевич 2-я Бауманская ул., 31, кв. 79 185-21-18 4 Колесникова Ирина Васильевна ул. Гордеева, 11, кв. 24 156-35-78 5 Колесников Сергей Анатольевич ул. Симбирцева, 156, кв. 148 140-14-85 6 Шабанов Иван Иванович ул. Панфилова, 142, кв. 46 159-45-89 7 Бурмистрова Инна Сергеена ул. Клочкова, 14, кв. 2 163-52-71 8 Желтухин Роман Романович 3-й Рельсовый пер-к, 13, кв. 9 158-48-79 9 Трубецкова Светлана Васильевна 1-я Бауманская ул., 74, кв. 15 158-56-71 10 Живайкина Людмила Викторовна пр-кт Вернадского, 121, кв. 56 405-85-89 Содержание таблицы Договора (Contract) Contract.dbf - Table CODE CLIENT_CODE INSURANC_CODE ON_DATE OFF_DATE 1 1 100102 13.06.2000 13.06.2005 2 1 100201 09.01.2000 09.01.2002 3 1 100301 09.01.1999 09.01.2004 4 2 100202 13.08.2000 13.02.2003 5 2 100102 19.09.1999 19.09.2004 6 3 100103 29.02.2000 28.02.2005 7 3 100101 26.11.2000 26.11.2005 8 4 100101 15.11.1998 15.11.2007 9 5 100102 16.08.1998 16.08.2003 10 5 100303 15.04.1999 15.04.2004 11 5 100202 07.02.1996 07.02.2001 12 5 100111 19.03.1996 19.03.2001 13 6 100101 14.06.1997 14.06.2002 14 6 100102 14.06.1997 14.06.2007 15 7 100101 15.09.1999 15.09.2004 16 8 100302 15.09.1999 15.09.2009 17 9 100303 10.01.2000 10.01.2010 18 9 100202 10.01.2000 10.01.2005 19 9 100101 10.01.2000 10.01.2003 20 10 100102 06.12.1998 06.12.2003 21 10 100203 14.11.1999 14.11.2004 22 10 100301 17.04.1999 17.04.2004 Содержание таблицы Страховки (Insurance) Insurance.dbf - Table INSURANC_CODE INSURANC_NAME COST 100102 Медицинская 1 50000 100103 Медицинская 2 100000 100111 Медицинская 3 10000 100201 Автомобильная 1 100000 100202 Автомобильная 2 500000 100203 Автомобильная 3 1000000 100301 Недвижимость 1 500000 100302 Недвижимость 2 1000000 100303 Недвижимость 3 10000000 5. ФОРМИРОВАНИЕ ЗАПРОСОВ Поиск нужной информации внутри таблиц базы данных и осуществление её выборки и представления по требуемом виде осуществляется посредством запросов, представляющих собой комплект условий отбора данных. Стандартным языком управления данными в реляционных СУБД является SQL, который мы и будем использовать при формировании запросов для выполнения задания. Для получения списка клиентов, имеющих страховки одного типа (ClientInsuranc), необходимо выполнить запрос к к трём таблицам Client, Contract, Insuranc. Причём для таблиц Contract и Clients необходимо установить связь по полю CLIENT_CODE, а для Contract и Insuranc по полю INSURANC_CODE: SELECT Client.NAME, Client.ADDRESS, Client.PHONE, Contract.CODE, Contract.INSURANC_CODE, Insurance.INSURANC_NAME, Contract.ON_DATE, Contract.OFF_DATE, Insurance.COST FROM (Client INNER JOIN Contract ON Client.CLIENT_CODE = Contract.CLIENT_CODE) INNER JOIN Insurance ON Contract.INSURANC_CODE = Insurance.INSURANC_CODE; Результаты выполнения запроса представляют собой таблицу из данных обусловленных запросом полей: ClientInsuranc.sql - SQL Results NAME ADDRESS PHONE CODE INSURANC_CODE INSURANC_NAME ON_DATE OFF_DATE COST Климов Алексей Иванович пр-кт Вернадского, 182, кв. 126 405-64-75 1 100102 Медицинская 1 13.06.2000 13.06.2005 50000 Климов Алексей Иванович пр-кт Вернадского, 182, кв. 126 405-64-75 2 100201 Автомобильная 1 09.01.2000 09.01.2002 100000 Климов Алексей Иванович пр-кт Вернадского, 182, кв. 126 405-64-75 3 100301 Недвижимость 1 09.01.1999 09.01.2004 500000 Аксёнов Сергей Евгеньевич Хамовнический вал, 25, кв. 74 172-58-69 4 100202 Автомобильная 2 13.08.2000 13.02.2003 500000 Аксёнов Сергей Евгеньевич Хамовнический вал, 25, кв. 74 172-58-69 5 100102 Медицинская 1 19.09.1999 19.09.2004 50000 Дудкин Степан Юрьевич 2-я Бауманская ул., 31, кв. 79 185-21-18 6 100103 Медицинская 2 29.02.2000 28.02.2005 100000 Колесников Сергей Анатольевич ул. Симбирцева, 156, кв. 148 140-14-85 9 100102 Медицинская 1 16.08.1998 16.08.2003 50000 Колесников Сергей Анатольевич ул. Симбирцева, 156, кв. 148 140-14-85 10 100303 Недвижимость 3 15.04.1999 15.04.2004 10000000 Колесников Сергей Анатольевич ул. Симбирцева, 156, кв. 148 140-14-85 11 100202 Автомобильная 2 07.02.1996 07.02.2001 500000 Колесников Сергей Анатольевич ул. Симбирцева, 156, кв. 148 140-14-85 12 100111 Медицинская 3 19.03.1996 19.03.2001 10000 Шабанов Иван Иванович ул. Панфилова, 142, кв. 46 159-45-89 14 100102 Медицинская 1 14.06.1997 14.06.2007 50000 Желтухин Роман Романович 3-й Рельсовый пер-к, 13, кв. 9 158-48-79 16 100302 Недвижимость 2 15.09.1999 15.09.2009 1000000 Трубецкова Светлана Васильевна 1-я Бауманская ул., 74, кв. 15 158-56-71 17 100303 Недвижимость 3 10.01.2000 10.01.2010 10000000 Трубецкова Светлана Васильевна 1-я Бауманская ул., 74, кв. 15 158-56-71 18 100202 Автомобильная 2 10.01.2000 10.01.2005 500000 Живайкина Людмила Викторовна пр-кт Вернадского, 121, кв. 56 405-85-89 20 100102 Медицинская 1 06.12.1998 06.12.2003 50000 Живайкина Людмила Викторовна пр-кт Вернадского, 121, кв. 56 405-85-89 21 100203 Автомобильная 3 14.11.1999 14.11.2004 1000000 Живайкина Людмила Викторовна пр-кт Вернадского, 121, кв. 56 405-85-89 22 100301 Недвижимость 1 17.04.1999 17.04.2004 500000 Установление связей между полями производиться с использованием визуальных возможностей Visual dBASE, для чего достаточно лишь "прочертить" линию, соединяющую эти поля, при помощи мыши. Результат объёдинения полей можно посмотреть на вкладке Join. Необходимо помнить об обязательности для связываемых полей в дочерней таблице статуса ключевого поля. Для родительских таблиц это необязательно. В данном случае родительской является таблица Contract. Получение перечня страховок, заключённых одним клиентом (InsurancClient) реализуем посредством запроса: SELECT Client.CLIENT_CODE, Client.NAME, Contract.CODE, Insurance.INSURANC_NAME, Contract.ON_DATE, Contract.OFF_DATE FROM (Client INNER JOIN Contract ON Client.CLIENT_CODE = Contract.CLIENT_CODE) INNER JOIN Insurance ON Contract.INSURANC_CODE = Insurance.INSURANC_CODE ORDER BY Client.NAME; Сортировку назначаем по алфавиту для фамилий клиентов. Результаты выполнения запроса: InsurancClient.sql - SQL Results CLIENT_CODE NAME CODE INSURANC_NAME ON_DATE OFF_DATE 2 Аксёнов Сергей Евгеньевич 4 Автомобильная 2 13.08.2000 13.02.2003 2 Аксёнов Сергей Евгеньевич 5 Медицинская 1 19.09.1999 19.09.2004 3 Дудкин Степан Юрьевич 6 Медицинская 2 29.02.2000 28.02.2005 8 Желтухин Роман Романович 16 Недвижимость 2 15.09.1999 15.09.2009 10 Живайкина Людмила Викторовна 21 Автомобильная 3 14.11.1999 14.11.2004 10 Живайкина Людмила Викторовна 20 Медицинская 1 06.12.1998 06.12.2003 10 Живайкина Людмила Викторовна 22 Недвижимость 1 17.04.1999 17.04.2004 1 Климов Алексей Иванович 2 Автомобильная 1 09.01.2000 09.01.2002 1 Климов Алексей Иванович 3 Недвижимость 1 09.01.1999 09.01.2004 1 Климов Алексей Иванович 1 Медицинская 1 13.06.2000 13.06.2005 5 Колесников Сергей Анатольевич 12 Медицинская 3 19.03.1996 19.03.2001 5 Колесников Сергей Анатольевич 9 Медицинская 1 16.08.1998 16.08.2003 5 Колесников Сергей Анатольевич 11 Автомобильная 2 07.02.1996 07.02.2001 5 Колесников Сергей Анатольевич 10 Недвижимость 3 15.04.1999 15.04.2004 9 Трубецкова Светлана Васильевна 17 Недвижимость 3 10.01.2000 10.01.2010 9 Трубецкова Светлана Васильевна 18 Автомобильная 2 10.01.2000 10.01.2005 6 Шабанов Иван Иванович 14 Медицинская 1 14.06.1997 14.06.2007 Сумма страховок за определённый период времени вычисляется на основе данных всех трёх таблиц: SELECT Insurance.INSURANC_NAME, Count(Insurance.INSURANC_CODE) AS Count_INSURANC_CODE, Sum(Insurance.COST) AS Sum_COST FROM (Client INNER JOIN Contract ON Client.CLIENT_CODE = Contract.CLIENT_CODE) INNER JOIN Insurance ON Contract.INSURANC_CODE = Insurance.INSURANC_CODE GROUP BY Insurance.INSURANC_NAME HAVING (((Count([ON_DATE]>[DATE1]))>-1) AND ((Count([OFF_DATE]<[DATE2]))>-1)) ORDER BY Insurance.INSURANC_NAME; При запуске запроса необходимо ввести в диалоговых окнах желаемые даты начала и окончания рассматриваемого периода. Выборка и подсчёт сумм будут выполнены автоматически. Результат запроса: DateSum.sql - SQL Results INSURANC_NAME Count_INSURANC_CODE Sum_COST Автомобильная 1 1 100000 Автомобильная 2 3 1500000 Автомобильная 3 1 1000000 Медицинская 1 5 250000 Медицинская 2 1 100000 Медицинская 3 1 10000 Недвижимость 1 2 1000000 Недвижимость 2 1 1000000 Недвижимость 3 2 20000000 6. ПРОЕКТИРОВАНИЕ ОТЧЁТОВ Таблица, содержащая результаты выполнения запроса практически малоудобна для чтения, поэтому упорядочивание, оформление и подготовка документа к печати производиться посредством отчётов. Источником данных для отчётов могут служить как сами таблицы, так и выборки запросов. Например, список кассет должен содержать заголовок и таблицу, содержащую наименование жанра, код кассеты, название фильма, фамилию главного героя. Отчёт создаём в диалоговом режиме: Через окно Navigator по вкладке Reports выбираем пункт меню Untitled. Задаём режим диалогового создания отчёта Wizard. Выбираем источник данных - ранее сформированные таблицу или запрос. Подтверждаем необходимость занесения в отчёт детальных строк. Из списка доступных полей выбираем необходимые к включению в отчёт посредством специального транспортирующего меню. Для каждой группы указываем принцип формирования итоговых строк с указанием функций и выражений. Вычисляемое поле в частности потребуется в отчёте по просроченным датам возврата кассет при определении итоговой суммы штрафов для каждого клиента. Формируем общий заголовок отчёта и параметры печатного листа. В режиме проектирования отчёта указываем также необходимые типы и размеры шрифтов, пояснительные текстовые вставки и т.п. По заданию формируем отчёты для получения: списка кассет по жанрам; списка кассет, взятых одним клиентом; списка клиентов-должников за текущий месяц с телефоном и адресом; Результаты контрольных распечаток отчётов приводим ниже. Клиенты Ф.И.О. Аксёнов Сергей Евгеньевич Адрес: Хамовнический вал, 25, кв. 74 Телефон: 172-58-69 Код Наименование № дог. Заключена Окончание Сумма 100202 Автомобильная 2 4 13.08.2000 13.02.2003 500000 100102 Медицинская 1 5 19.09.1999 19.09.2004 50000 Ф.И.О. Дудкин Степан Юрьевич Адрес: 2-я Бауманская ул., 31, кв. 79 Телефон: 185-21-18 Код Наименование № дог. Заключена Окончание Сумма 100103 Медицинская 2 6 29.02.2000 28.02.2005 100000 Ф.И.О. Желтухин Роман Романович Адрес: 3-й Рельсовый пер-к, 13, кв. 9 Телефон: 158-48-79 Код Наименование № дог. Заключена Окончание Сумма 100302 Недвижимость 2 16 15.09.1999 15.09.2009 1000000 Ф.И.О. Живайкина Людмила Адрес: пр-кт Вернадского, 121, кв. 56 Телефон: 405-85-89 Код Наименование № дог. Заключена Окончание Сумма 100203 Автомобильная 3 21 14.11.1999 14.11.2004 1000000 100102 Медицинская 1 20 06.12.1998 06.12.2003 50000 100301 Недвижимость 1 22 17.04.1999 17.04.2004 500000 Ф.И.О. Климов Алексей Иванович Адрес: пр-кт Вернадского, 182, кв. 126 Телефон: 405-64-75 Код Наименование № дог. Заключена Окончание Сумма 100201 Автомобильная 12 09.01.2000 09.01.2002 100000 100102 Медицинская 1 1 13.06.2000 13.06.2005 50000 100301 Недвижимость 1 3 09.01.1999 09.01.2004 500000 Ф.И.О. Колесников Сергей Анатольевич Адрес: ул. Симбирцева, 156, кв. 148 Телефон: 140-14-85 Код Наименование № дог. Заключена Окончание Сумма 100202 Автомобильная 2 11 07.02.1996 07.02.2001 500000 100102 Медицинская 1 9 16.08.1998 16.08.2003 50000 100111 Медицинская 3 12 19.03.1996 19.03.2001 10000 100303 Недвижимость 3 10 15.04.1999 15.04.2004 10000000 Ф.И.О. Трубецкова Светлана Васильевна Адрес: 1-я Бауманская ул., 74, кв. 15 Телефон: 158-56-71 Код Наименование № дог. Заключена Окончание Сумма 100202 Автомобильная 2 18 10.01.2000 10.01.2005 500000 100303 Недвижимость 3 17 10.01.2000 10.01.2010 10000000 Ф.И.О. Шабанов Иван Иванович Адрес: ул. Панфилова, 142, кв. 46 Телефон: 159-45-89 Код Наименование № дог. Заключена Окончание Сумма 100102 Медицинская 1 14 14.06.1997 14.06.2007 50000 Страховки Наименование Ф.И.О. Код Заключ. Оконч. Автомобильная 1 № дог. 2 Климов Алексей Иванович 1 09.01.2000 09.01.2002 Автомобильная 2 № дог. 4 Аксёнов Сергей Евгеньевич 2 13.08.2000 13.02.2003 № дог. 11 Колесников Сергей Анатольевич 5 07.02.1996 07.02.2001 № дог. 18 Трубецкова Светлана Васильевна 9 10.01.2000 10.01.2005 Автомобильная 3 № дог. 21 Живайкина Людмила Викторовна 10 14.11.1999 14.11.2004 Медицинская 1 № дог. 5 Аксёнов Сергей Евгеньевич 2 19.09.1999 19.09.2004 № дог. 20 Живайкина Людмила Викторовна 10 06.12.1998 06.12.2003 № дог. 1 Климов Алексей Иванович 1 13.06.2000 13.06.2005 № дог. 9 Колесников Сергей Анатольевич 5 16.08.1998 16.08.2003 № дог. 14 Шабанов Иван Иванович 6 14.06.1997 14.06.2007 Медицинская 2 № дог. 6 Дудкин Степан Юрьевич 3 29.02.2000 28.02.2005 Медицинская 3 № дог. 12 Колесников Сергей Анатольевич 5 19.03.1996 19.03.2001 Недвижимость 1 № дог. 22 Живайкина Людмила Викторовна 10 17.04.1999 17.04.2004 № дог. 3 Климов Алексей Иванович 1 09.01.1999 09.01.2004 Недвижимость 2 № дог. 16 Желтухин Роман Романович 8 15.09.1999 15.09.2009 Недвижимость 3 № дог. 10 Колесников Сергей Анатольевич 5 15.04.1999 15.04.2004 № дог. 17 Трубецкова Светлана Васильевна 9 10.01.2000 10.01.2010 11 декабря 2000 г. Страница 2 из 2 Сумма страховых договоров за период с C 06/08/00 ПО 06/08/05 Название страховки Количество договоров Стоимость Автомобильная 1 1 100000 Автомобильная 2 3 1600000 Автомобильная 3 1 2600000 Медицинская 1 5 2850000 Медицинская 2 1 2950000 Медицинская 3 1 2960000 Недвижимость 1 2 3960000 Недвижимость 2 1 4960000 Недвижимость 3 2 24960000 Итого: 20000000 11 декабря 2000 г. Страница 1 из 1 7. РАССЫЛКА ПРИГЛАШЕНИЙ Выполняем при помощи создания отчёта с полями, заполняемыми на основе данных из полей ADDRESS и NAME таблицы Client. г. Москва Хамовнический вал, 25, кв. 74 Аксёнов Сергей Евгеньевич Уважаемый(ая) Аксёнов Сергей Евгеньевич Приглашаем Вас на презентацию пакета услуг страховой компании "Элвис", которая состоится в 14.00 15 января 2001 года по адресу: г. Москва, ул. Зеленая, 17. Президент компании __________________ /Астафьев Л.С./ г. Москва ул. Клочкова, 14, кв. 2 Бурмистрова Инна Сергеена Уважаемый(ая) Бурмистрова Инна Сергеена Приглашаем Вас на презентацию пакета услуг страховой компании "Элвис", которая состоится в 14.00 15 января 2001 года по адресу: г. Москва, ул. Зеленая, 17. Президент компании __________________ /Астафьев Л.С./ г. Москва 2-я Бауманская ул., 31, кв. 79 Дудкин Степан Юрьевич Уважаемый(ая) Дудкин Степан Юрьевич Приглашаем Вас на презентацию пакета услуг страховой компании "Элвис", которая состоится в 14.00 15 января 2001 года по адресу: г. Москва, ул. Зеленая, 17. Президент компании __________________ /Астафьев Л.С./ 11 декабря 2000 г. Страница 1 из 3 г. Москва 3-й Рельсовый пер-к, 13, кв. 9 Желтухин Роман Романович Уважаемый(ая) Желтухин Роман Романович Приглашаем Вас на презентацию пакета услуг страховой компании "Элвис", которая состоится в 14.00 15 января 2001 года по адресу: г. Москва, ул. Зеленая, 17. Президент компании __________________ /Астафьев Л.С./ г. Москва пр-кт Вернадского, 121, кв. 56 Живайкина Людмила Викторовна Уважаемый(ая) Живайкина Людмила Викторовна Приглашаем Вас на презентацию пакета услуг страховой компании "Элвис", которая состоится в 14.00 15 января 2001 года по адресу: г. Москва, ул. Зеленая, 17. Президент компании __________________ /Астафьев Л.С./ г. Москва пр-кт Вернадского, 182, кв. 126 Климов Алексей Иванович Уважаемый(ая) Климов Алексей Иванович Приглашаем Вас на презентацию пакета услуг страховой компании "Элвис", которая состоится в 14.00 15 января 2001 года по адресу: г. Москва, ул. Зеленая, 17. Президент компании __________________ /Астафьев Л.С./ г. Москва ул. Симбирцева, 156, кв. 148 Колесников Сергей Анатольевич Уважаемый(ая) Колесников Сергей Анатольевич Приглашаем Вас на презентацию пакета услуг страховой компании "Элвис", которая состоится в 14.00 15 января 2001 года по адресу: г. Москва, ул. Зеленая, 17. Президент компании __________________ /Астафьев Л.С./ 11 декабря 2000 г. Страница 2 из 3 г. Москва ул. Гордеева, 11, кв. 24 Колесникова Ирина Васильевна Уважаемый(ая) Колесникова Ирина Васильевна Приглашаем Вас на презентацию пакета услуг страховой компании "Элвис", которая состоится в 14.00 15 января 2001 года по адресу: г. Москва, ул. Зеленая, 17. Президент компании __________________ /Астафьев Л.С./ г. Москва 1-я Бауманская ул., 74, кв. 15 Трубецкова Светлана Васильевна Уважаемый(ая) Трубецкова Светлана Васильевна Приглашаем Вас на презентацию пакета услуг страховой компании "Элвис", которая состоится в 14.00 15 января 2001 года по адресу: г. Москва, ул. Зеленая, 17. Президент компании __________________ /Астафьев Л.С./ г. Москва ул. Панфилова, 142, кв. 46 Шабанов Иван Иванович Уважаемый(ая) Шабанов Иван Иванович Приглашаем Вас на презентацию пакета услуг страховой компании "Элвис", которая состоится в 14.00 15 января 2001 года по адресу: г. Москва, ул. Зеленая, 17. Президент компании __________________ /Астафьев Л.С./ 11 декабря 2000 г. Страница 3 из 3 СПИСОК ЛИТЕРАТУРЫ Информатика: учебник / под. ред. проф. Н.В. Макаровой. - М.: Финансы и статистика, 1997. Хенсем Г., Камарга Б. Базы данных: реализация и управление. - М.: Финансы и статистика, 1995. Том Д. Эволюция документных баз данных. - М.: ЭлисКом, 1999. Закис А. Технология создания и кастомизации офисных информационных систем. М.: DataX/Florin, 1999. 2 Работа на этой странице представлена для Вашего ознакомления в текстовом (сокращенном) виде. Для того, чтобы получить полностью оформленную работу в формате Word, со всеми сносками, таблицами, рисунками, графиками, приложениями и т.д., достаточно просто её СКАЧАТЬ. |
|
Copyright © refbank.ru 2005-2025
Все права на представленные на сайте материалы принадлежат refbank.ru. Перепечатка, копирование материалов без разрешения администрации сайта запрещено. |
|