Лабораторная работа №1. Методические рекомендации по выполнению лабораторной работы 2 Персональный компьютер ibm pc 3 Последовательность выполнения работы
Скачать 183.86 Kb.
|
1 2 МИНИСТЕРСТВО ОБРАЗОВАНИЯ РЕСПУБЛИКИ БЕЛАРУСЬ УПРАВЛЕНИЕ ОБРАЗОВАНИЯ МОГИЛЕВСКОГО ОБЛАСТНОГО ИСПОЛНИТЕЛЬНОГО КОМИТЕТА УЧРЕЖДЕНИЕ ОБРАЗОВАНИЯ “МОГИЛЕВСКИЙ ГОСУДАРСТВЕННЫЙ ПОЛИТЕХНИЧЕСКИЙ КОЛЛЕДЖ” Дисциплина Базы данных и системы управления базами данных УТВЕРЖДАЮ Заместитель директора по учебной работе _________М.М. Федоськова ________________________ ЛАБОРАТОРНАЯ РАБОТА № 1 Построение структуры реляционной БД МЕТОДИЧЕСКИЕ РЕКОМЕНДАЦИИ Разработала преподаватель Старовойтова А.А. 2016 Обсуждено и одобрено на заседании цикловой комиссии спецдисциплин специальности «Программное обеспечение информационных технологий» Протокол № __ от _____________________ 1 Цель работы1.1 Формирование умений строить диаграммы UML для баз данных 2 Методическое и материальное обеспечение 2.1 Методические рекомендации по выполнению лабораторной работы 2.2 Персональный компьютер IBM PC 3 Последовательность выполнения работы 3.1 Изучить теоретическое обоснование лабораторной работы 3.2 Создать структуру реляционной базы данных с использованием диаграмм UML 3.3 Составить отчет 3.4 Составить ответы на контрольные вопросы 3.5 Предоставить отчет преподавателю для проверки 4 Теоретическое обоснование 4.1 Диаграммы классов Диаграммы классов - это наиболее часто используемый тип диаграмм, которые создаются при моделировании объектно-ориентированных систем. Показывают набор классов, интерфейсов и коопераций, а также их связи. На практике диаграммы классов применяют для моделирования статического представления системы (по большей части это моделирование словаря системы, коопераций или схем). Кроме того, диаграммы данного типа служат основой для целой группы взаимосвязанных диаграмм - диаграмм компонентов и диаграмм размещения. Диаграммы классов важны не только для визуализации, специфицирования и документирования структурных моделей, но также для конструирования исполняемых систем посредством прямого и обратного проектирования. В любом деле, например строительстве дома, не обойтись без понятийного аппарата - в данном случае словаря, который включает основные строительные блоки: стены, полы, окна, двери, потолки, перекрытия. Эти элементы в значительной мере структурированы (стены имеют высоту, ширину и толщину), но притом каждый из них ведет себя определенным образом (стены разных типов несут разные нагрузки; двери могут открываться и закрываться в разные стороны; существуют ограничения на размер пролетов, образуемых перекрытиями). Нельзя рассматривать эти структурные и поведенческие параметры независимо друг от друга: при строительстве понадобится учитывать, как они взаимодействуют. Процесс проектирования дома, таким образом, включает в себя компоновку всех вышеперечисленных сущностей в уникальной манере, подчиняющейся велениям здравого смысла и призванной удовлетворить все ваши функциональные и нефункциональные требования. Разработка программного обеспечения ведется примерно по той же схеме - за исключением того, что благодаря гибкости ПО, есть возможность определять «с нуля» свои собственные базовые строительные блоки. Диаграммы классов в UML используются для того, чтобы визуализировать статические аспекты этих строительных блоков и их связей, а также обозначить детали их конструирования. Диаграмма классов - это диаграмма, которая показывает набор классов, интерфейсов, коопераций и их связи. Графически представляет собой набор вершин и связывающих их дуг. Диаграмма классов, как и любая другая диаграмма, обладает именем и содержимым, которое является проекцией модели. От других типов диаграмм отличается конкретным наполнением. На диаграммах классов обычно представлены следующие элементы: классы; интерфейсы; зависимости, обобщения и ассоциации. Как и другие диаграммы, они могут содержать примечания и ограничения. Центральное место в ООАП занимает разработка логической модели системы в виде диаграммы классов. Диаграмма классов (class diagram) служит для представления статической структуры модели системы в терминологии классов объектно‑ориентированного программирования. Диаграмма классов может отражать, в частности, различные взаимосвязи между отдельными сущностями предметной области, такими как объекты и подсистемы, а также описывает их внутреннюю структуру и типы отношений. На данной диаграмме не указывается информация о временных аспектах функционирования системы. Когда говорят о данной диаграмме, имеют в виду статическую структурную модель проектируемой системы. Поэтому диаграмму классов принято считать графическим представленном таких структурных взаимосвязей логической модели системы, которые не зависят или инвариантны от времени. Диаграмма классов состоит из множества элементов, которые в совокупности отражают декларативные знания о предметной области. При этом отдельные компоненты этой диаграммы могут образовывать пакеты для представления более общей модели системы. В общем случае пакет статической структурной модели может быть представлен в виде одной или нескольких диаграмм классов. 4.2 Стандартное использование Прорабатывая статическое представление системы, обычно используются диаграммы классов с одной из трех целей: – Для моделирования словаря системы. Моделирование словаря системы предполагает решение вопроса о том, какие абстракции станут предметом внимания системы, а какие выходят за ее границы. – Для моделирования простых коопераций. Кооперация - это сообщество классов, интерфейсов и других элементов, которые работают в совокупности для формирования некоторого совместного поведения, которое не может быть обеспечено всеми этими элементами, взятыми в отдельности. Диаграмма классов позволит визуализировать и специфицировать такой набор классов и их связей. – Для моделирования логической схемы базы данных. Схему в данном контексте можно рассматривать как проект концептуального дизайна базы данных. Во многих областях требуется сохранять информацию в реляционной или объектно-ориентированной базе данных. Их схемы удобно моделировать при помощи диаграмм классов. 4.3 Класс Класс в языке UML служит для обозначения множества объектов, которые обладают одинаковой структурой, поведением и отношениями с объектами из других классов. Графически класс изображается в виде прямоугольника, который дополнительно может быть разделен горизонтальными линиями на разделы или секции. В этих разделах могут указываться имя класса, атрибуты (переменные) и операции (методы) (см. рисунок 1). Рисунок 1 – Графическое изображение класса Обязательным элементов обозначения класса является его имя. На начальных этапах разработки диаграммы отдельные классы могут обозначаться простым прямоугольником с указанием только имени соответствующего класса. По мере проработки отдельных компонентов диаграммы описания классов дополняются атрибутами и операциями. Предполагается, что окончательный вариант диаграммы содержит наиболее полное описание классов, которые состоят из трех разделов или секций. Иногда в обозначениях классов используется дополнительный четвертый раздел, в котором приводится семантическая информация справочного характера или явно указываются исключительные ситуации. Даже если секция атрибутов и операций является пустой, в обозначении класса она выделяется горизонтальной линией, чтобы сразу отличить класс от других элементов языка UML (см. рисунок 2). Рисунок 2 – Графическое изображение класса с секциями 4.4 Имя класса Имя класса должно быть уникальным в пределах пакета, который описывается некоторой совокупностью диаграмм классов (возможно, одной диаграммой). Оно указывается в первой верхней секции прямоугольника. В дополнение к общему правилу наименования элементов языка UML, имя класса записывается по центру секции имени полужирным шрифтом и должно начинаться с заглавной буквы. Рекомендуется в качестве имен классов использовать существительные, записанные по практическим соображениям без пробелов. Необходимо помнить, что именно имена классов образуют словарь предметной области при ООАП. Примерами имен классов могут быть такие существительные, как «Сотрудник», «Компания», «Руководитель», «Клиент», «Продавец», «Менеджер», «Офис» и многие другие, имеющие непосредственное отношение к моделируемой предметной области и функциональному назначению проектируемой системы. Класс может не иметь экземпляров или объектов. В этом случае он называется абстрактным классом, а для обозначения его имени используется наклонный шрифт (курсив). 4.5 Атрибуты класса Во второй сверху секции прямоугольника класса записываются его атрибуты или свойства. В языке UML принята определенная стандартизация записи атрибутов класса, которая подчиняется некоторым синтаксическим правилам. Каждому атрибуту класса соответствует отдельная строка текста, которая состоит из квантора видимости атрибута, имени атрибута, его кратности, типа значений атрибута и, возможно, его исходного значения: ‹квантор видимости›‹имя атрибута›[кратность]: ‹тип атрибута› = ‹исходное значение›{строка‑свойство} Квантор видимости может принимать одно из трех возможных значений и, соответственно, отображается при помощи специальных символов: Символ "+" обозначает атрибут с областью видимости типа общедоступный (public). Атрибут с этой областью видимости доступен или виден из любого другого класса пакета, в котором определена диаграмма. Символ "#" обозначает атрибут с областью видимости типа защищенный (protected). Атрибут с этой областью видимости недоступен или невиден для всех классов, за исключением подклассов данного класса. Знак «‑» обозначает атрибут с областью видимости типа закрытый (private). Атрибут с этой областью видимости недоступен или невиден для всех классов без исключения. Квантор видимости может быть опущен. В этом случае его отсутствие просто означает, что видимость атрибута не указывается. Вместо условных графических обозначений можно записывать соответствующее ключевое слово: public, protected, private. Имя атрибута представляет собой строку текста, которая используется в качестве идентификатора соответствующего атрибута и поэтому должна быть уникальной в пределах данного класса. Имя атрибута является единственным обязательным элементом синтаксического обозначения атрибута. Кратность атрибута характеризует общее количество конкретных атрибутов данного типа, входящих в состав отдельного класса. В общем случае кратность записывается в форме строки текста в квадратных скобках после имени соответствующего атрибута: [нижняя_граница1… верхняя_граница1, нижняя_граница2… верхняя_граница2,… нижняя_гpaницak… верхняя_границаk] В качестве верхней_границы может использоваться специальный символ "*", который означает произвольное положительное целое число. Другими словами, это означает неограниченное сверху значение кратности соответствующего атрибута. Значения кратности из интервала следуют в монотонно возрастающем порядке без пропуска отдельных чисел, лежащих между нижней и верхней границами. При этом придерживаются следующего правила: соответствующие нижние и верхние границы интервалов включаются в значение кратности. Если в качестве кратности указывается единственное число, то кратность атрибута принимается равной данному числу. Если же указывается единственный знак "*", то это означает, что кратность атрибута может быть произвольным положительным целым числом или нулем. В качестве примера рассмотрим следующие варианты задания кратности атрибутов: [0…1] означает, что кратность атрибута может принимать значение 0 или 1. При этом 0 означает отсутствие значения для данного атрибута; [0…*] означает, что кратность атрибута может принимать любое положительное целое значение большее или равное 0. Эта кратность может быть записана короче в виде простого символа – [*]; [1.:*] означает, что кратность атрибута может принимать любое положительное целое значение большее или равное 1; [1…5] означает, что кратность атрибута может принимать любое значение из чисел: 1, 2, 3, 4, 5; [1…3,5,7] означает, что кратность атрибута может принимать любое значение из чисел: 1, 2, 3, 5, 7; [1…3,7… 10] означает, что кратность атрибута может принимать любое значение из чисел: 1, 2, 3, 7, 8, 9, 10; [1…3,7…*] означает, что кратность атрибута может принимать любое значение из чисел: 1, 2, 3, а также любое положительное целое значение большее или равное 7. Если кратность атрибута не указана, то по умолчанию принимается ее значение равное 1…1, т. е. в точности 1. Тип атрибута представляет собой выражение, семантика которого определяется языком спецификации соответствующей модели. В нотации UML тип атрибута иногда определяется в зависимости от языка программирования, который предполагается использовать для реализации данной модели. Можно привести следующие примеры задания имен и типов атрибутов классов: цвет: Соlоr – здесь цвет является именем атрибута, Color – именем типа данного атрибута. Указанная запись может определять традиционно используемую RGB‑модель (красный, зеленый, синий) для представления цвета. В этом случае имя типа Color как раз и характеризует семантическую конструкцию, которая применяется в большинстве языков программирования для представления цвета; имя_сотрудника [1…2]: String – здесь имя_сотрудника является именем атрибута, который служит для представления информации об имени, а возможно, и отчестве конкретного сотрудника. Тип атрибута String (Строка) как раз и указывает на тот факт, что отдельное значение имени представляет собой строку текста из одного или двух слов (например, «Кирилл» или «Дмитрий Иванович»). Поскольку во многих языках программирования существует тип данных String, использование соответствующего англоязычного термина не вызывает недоразумения у большинства программистов. Однако, хотя в языке UML все термины даются в англоязычном представлении, использование в качестве типа атрибута Строка в данной ситуации не исключается и определяется только соображениями удобства; видимость: Boolean – здесь видимость есть имя абстрактного атрибута (курсив здесь не случаен), который может характеризовать наличие визуального представления соответствующего класса на экране монитора. В этом случае тип Boolean означает, что возможными значениями данного атрибута является одно из двух логических значений: истина (true) или ложь (false). При этом значение истина может соответствовать наличию графического изображения на экране монитора, а значение ложь – его отсутствию, о чем дополнительно указывается в пояснительном тексте. Поскольку кратность атрибута видимость не указана, она принимает значение 1 по умолчанию. В этой ситуации англоязычное имя типа атрибута вполне оправдано наличием соответствующего базового типа в языках программирования. Абстрактный характер данного атрибута обозначается курсивным текстом в записи данного атрибута; форма: Многоугольник – здесь имя атрибута форма может характеризовать такой класс, который является геометрической фигурой на плоскости. В этом случае тип атрибута Многоугольник указывает на тот факт, что отдельная геометрическая фигура может иметь форму треугольника, прямоугольника, ромба, пятиугольника и любого другого многоугольника, но не окружности или эллипса. Вполне очевидно, что в данной ситуации использование соответствующего англоязычного термина вряд ли целесообразно, поскольку тип Многоугольник не является базовым для языков программирования. Исходное значение служит для задания некоторого начального значения для соответствующего атрибута в момент создания отдельного экземпляра класса. Здесь необходимо придерживаться правила принадлежности значения типу конкретного атрибута. Если исходное значение не указано, то значение соответствующего атрибута не определено на момент создания нового экземпляра класса. С другой стороны, конструктор соответствующего объекта может переопределять исходное значение в процессе выполнения программы, если в этом возникает необходимость. В качестве примеров исходных значений атрибутов можно привести следующие дополненные выше варианты задания атрибутов: – цвет: Соlоr = (255, 0, 0) – в RGB‑модели цвета это соответствует чистому красному цвету в качестве исходного значения для данного атрибута; – имя_сотрудника[1…2]: String = Иван Иванович – соответствует ситуации имя_руководителя:String = Иван Иванович; – видимость: Вооlеаn = истина – может соответствовать ситуации, когда в момент создания экземпляра класса создается видимое на экране монитора окно, соответствующее данному объекту; – форма: Многоугольник = прямоугольник – вряд ли требует комментариев, поскольку здесь речь идет о геометрической форме создаваемого объекта. При задании атрибутов могут быть использованы две дополнительные синтаксические конструкции – это подчеркивание строки атрибута и пояснительный текст в фигурных скобках. Подчеркивание строки атрибута означает, что соответствующий атрибут может принимать подмножество значений из некоторой области значений атрибута, определяемой его типом. Эти значения можно рассматривать как набор однотипных записей или массив, которые в совокупности характеризуют каждый объект класса. Например, если некоторый атрибут задан в виде форма: Прямоугольник, то это будет означать, что все объекты данного класса могут иметь несколько различных форм, каждая из которых является прямоугольником. Другим примером может служить задание атрибута в виде номер_счета: Integer. что может означать для объекта Сотрудник наличие некоторого подмножества счетов, общее количество которых заранее не фиксируется. Строка‑свойство служит для указания значений атрибута, которые не могут быть изменены в программе при работе с данным типом объектов. Фигурные скобки как раз и обозначают фиксированное значение соответствующего атрибута для класса в целом, которое должны принимать все вновь создаваемые экземпляры класса без исключения. Это значение принимается за исходное значение атрибута, которое не может быть переопределено в последующем. Отсутствие строки‑свойства по умолчанию трактуется так, что значение соответствующего атрибута может быть изменено в программе. Например, строка‑свойство в записи атрибута заработная_плата: Currency = = {$500} может служить для обозначения фиксированной заработной платы для каждого объекта класса «Сотрудник» определенной должности в некоторой организации. С другой стороны, запись данного атрибута в виде заработная_плата: Currency = $500 означает уже нечто иное, а именно – при создании нового экземпляра Сотрудник (аналогия – прием на работу нового сотрудника) для него устанавливается по умолчанию заработная плата в $500. Однако для отдельных сотрудников могут быть сделаны исключения, как в большую, так и в меньшую сторону, о чем необходимо позаботиться дополнительно в программе. 1 2 |