Учебное пособие: Методические указания для выполнения курсового проекта по дисциплине «Базы данных»
Название: Методические указания для выполнения курсового проекта по дисциплине «Базы данных» Раздел: Остальные рефераты Тип: учебное пособие | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Федеральное агентство по образованию Армавирский машиностроительный техникум Методические указания для выполнения курсового проекта по дисциплине «Базы данных» для специальности 230105 «Программное обеспечение вычислительной техники и автоматизированных систем» 2008
Введение. В данном методическом пособии представлены указания для выполнения практических работ по дисциплине «Разработка и эксплуатация удалённых баз данных» для специальности 230105 «Программное обеспечение вычислительной техники и автоматизированных систем». Цели и задачи предлагаемого пособия: · получение практических навыков реализации базы данных в среде MS SQL Server 2005 ; · формирование навыков построения простых и сложных запросов с помощью языка SQL Transact · управление транзакциями в базе данных · получение практических навыков построения процедур и триггеров. · обеспечение безопасности работы пользователей в архитектуре «клиент - сервер» · получение практических навыков разработки «клиентской» части приложения в MS Access. · Рассматриваемый курс содержит: 17 практических занятия; приложений, списка литературы. Каждое занятие состоит из следующих структурных частей: · изучение теоретического материала; · выполнение заданий. · выполнение контрольных заданий
Пояснительная записка Курсовое проектирование проводится в рамках дисциплины «Базы данных по специальности 230105 Программное обеспечение вычислительной техники и автоматизированных систем. Курсовое проектирование базируется на знаниях и навыках, полученных при изучении следующих предметов: - Базы данных - Операционные системы - Информатика - Основы алгоритмизации и программирования. После выполнения курсового проекта студент должен: знать: · Основы построения информационных систем и баз данных; · Методику анализа предметной области и ее реализацию инструментальными средствами; · Основы проектирования таблиц, отношений между таблицами. · Методы проектирования и реализации запросов уметь: · создавать структуры таблиц ; · использовать мастер подстановок при построении отношений между таблицами; · реализовывать простые запросы; · реализовывать сложные запросы ( последовательность взаимосвязанных запросов) · создавать запросы на изменение данных; · разрабатывать интерфейс с пользователем. Введение . Выполнение курсовой работы по дисциплине Базы данных предусмотрено учебным планом. Курсовая работа оформляется в машинописной форме и является обязательной формой отчёта. она состоит из теоретической части и практической реализации. выполненная курсовая работа проверяется преподавателем. если она соответствует требованиям, то выдаётся рецензия с рекомендацией к защите, в противном случае она возвращается да доработку. Защита курсовой работы проводится студентом на персональном компьютере в установленные сроки при наличии рецензии. Цель выполнения курсовой работы – проектирование информационной системы базы данных. База данных должна сопровождаться подробным руководством пользователя. Оформление курсовой работы. На каждой странице оставляются поля не менее 3 см для замечаний преподавателя. Страницы должны быть пронумерованы, в колонтитулах указывается год, номер студента по журналу в группе. Например, колонтитул для студента, выполнившего курсовой проект в 2008 году с номером по журналу ‘3’: АМТ. 08.КП.03 . Структура курсовой работы. В курсовой работе должен быть проведён общий анализ предметной области ( ПО); определены функции, которые реализуются в разработанной базе данных; указаны ограничения, если таковые имеются. На основе анализа осуществляется постановка комплекса рассматриваемых задач. 1. Анализ предметной области. 1.1. Описание предметной области и функции решаемых задач. 1.2. Перечень входных данных. 1.3. Перечень выходных данных. 1.4. Ограничения предметной области ( если таковые имеются). 1.5. Взаимодействие с другими программами. 2. Постановка задачи 3. Проектирование концептуальной модели 3.1 Выделение информационных объектов. 3.2 Определение атрибутов объектов. 3.3 Определение отношений и мощности отношений между объектами. 3.4 Построение схемы концептуальной модели. 4. Разработка логической структуры базы данных. 5. Реляционная модель. 6. Определение типов данных в заданном формате (структура таблиц; типы данных; ключевые элементы; внешние ключи) 7. Создание глобальной схемы связей. Поддержка целостности данных. 8. Запросы. Структура и назначение. SQL-запрос. 9. Проектирование форм. Структура и назначение существующих форм. 10. Структура отчетов. 11. Макросы. Назначение и алгоритм работы. 12. Структура главной кнопочной формы. 13. Руководство пользователя. 14. Заключение. 15. Список использованных источников 16.Графическое приложение. 16.1 Экранные формы проекта. 16.2 Отчёты. Проектирование информационной системы на основе базы данных. Проектирование информационной системы базы данных основывается на исследовании информации, циркулирующей внутри данной предметной области. Предметная область (ПО ) – это совокупность объектов, процессов и связей между ними ( банк, завод, склад и т. д.). При обследовании ПО выполняется семантический анализ информации данной предметной области. Семантика – это смысловая сторона информации. Рассмотрим некоторые понятия, необходимые для описания исследуемой предметной области. Информационный объект(ИО) - источник информации. он может быть материальным ( цех, склад, документ …) и нематериальным ( факты, события, процессы, явления...). Информационный объект – это любая реальная или абстрактная сущность, о которой накапливается информация. Сведения об объектах могут поступать из различных сообщений и документов. Каждый объект характеризуется набором атрибутов. Атрибуты – это свойства, которыми обладает данный объект. Атрибут является простейшей неделимой единицей информации, которая отражает количественную или качественную характеристику объекта. Сведения об атрибутах получают на этапе предпроектного обследования. Здесь же учитываются ограничения и допущения. Состав атрибутов представляет собой структуру информационного объекта. Атрибуты, которые однозначно определяют каждый экземпляр объекта, являются ключевыми . По значению ключа можно отыскать нужный экземпляр объекта. Другие атрибуты объекта называются неключевыми или описательными. Ключ и описательные атрибуты находятся в функциональной зависимости. Ключ может быть простым и составным . Например в объекте «студент» будет составной ключ: номер_группы + номер_студента Информация в реляционных базах данных хранится в нескольких взаимосвязанных двумерных таблицах, в каждой из которых находится информация об одном объекте. Между всеми объектами, выявленными в предпроектном проектировании, надо установить типы связей. Связи могут быть «один – к - одному» ( 1:1), «один – ко - многим» ( 1:N), «многие – ко - многим» (N:N). Связь «один – к - одному » имеет место, когда каждому экземпляру одного объектного множества соответствует только один экземпляр другого объектного множества. Связь «один – ко - многим » имеет место, когда каждому экземпляру одного объектного множества соответствует несколько экземпляров другого объектного множества. Этот тип связи наиболее часто используется в концептуальной модели. Связь «один – ко - многим » имеет место, когда каждому экземпляру одного объектного множества соответствует несколько экземпляров другого объектного множества. И наоборот, каждому экземпляру второго объектного множества соответствует несколько экземпляров первого объектного множества. На основании выявленных связей строится концептуальная модель. Пример разработки информационной системы 1. Анализ предметной области . 1.1. Описание предметной области и функции решаемых задач. В качестве примера рассмотрим упрощённый вариант построения информационной системы для работы туристического агентства. Предметной областью автоматизации являются должностные функции менеджера по продажам путёвок. Сотрудники оформляют тур. путёвки и путёвки в санаторий для клиентов. 1.2 Перечень входных данных. Входную информацию делят на условно-постоянную, сохраняющую свои значения на длительный период времени, и, на постоянно меняющуюся оперативно-учётную. В результате обследования предметной области определены входные данные, необходимые для решения комплекса задач: Тур.путёвки, путёвки в санаторий, информация о клиентах, информация о странах. Поэтому при разработке базы данных, необходимо создать формы для ввода этой информации. Входная информация может быть представлена следующими документами:
Таблица 1. Входные данные по клиенту
Таблица 2. Входные данные по путёвкам
Примечание : по возможности входная информация представляется в графическом виде 1.3. Перечень выходных данных . Выходная информация представляется в виде отчётов.
Выходную информацию представим в виде отчётных форм: не оплаченные путёвки Клиенты № тура Оплата Стоимость Смирнов Д.А. Золотой песок Не оплачено 500 … … … … самый дешёвый тур Страна Начало Продолжитель № Название Транспорт Стои Колич тура ность тура тура тура мост ство 1.4. Ограничения предметной области . По рассматриваемой предметной области введём некоторые ограничения : - В таблице «путёвки» значение поля «стоимость» должно быть больше нуля. - В таблице «путёвки» значение поля «количество» должно быть больше нуля. - В таблице «путёвки в санаторий» значение поля «дата окончания пребывания» должна вычисляться как сумма «даты начала» и «продолжительности». 1.5. Взаимодействие с другими программами. Представленная информационная система должна выводить отчёты в текстовый редактор MS Word. Прайс-лист о путёвках может выводится в MS Excel. 2. Постановка задачи Разрабатываемая информационная система предназначена для структурированного хранения данных и вывода информации о турах по странам, путёвках туров, клиентах Разрабатываемая информационная система должна выполнять следующие функции:
3. Проектирование концептуальной модели 3.1 Выделение информационных объектов. Одним из первых объектов предметной области можно выделить «тур путёвки» и «путёвки в санаторий». Далее определяем, кто оформляет путёвки, для этого вводим объект «сотрудник». Путёвки покупаются клиентами ( объект «клиент»).Тур путёвки продаются в разные страны, отсюда объект «страна». Переезд в туристических путёвках осуществляется транспортом, поэтому возникает необходимость в объекте «транспорт». Клиентам необходимо представлять список санаториев, куда он может поехать (объект «санаторий» ). В санаториях выполняют лечение заболеваний (объект «заболевание»). Объект «оформление путёвки» является сложным, так как включает в себя несколько объектов: «клиенты», «путёвки», «сотрудники» 3.2 Определение атрибутов объектов . Рассмотрим атрибуты перечисленных объектов. Таблица 3. Атрибуты объектов
Необходимо проанализировать каждый атрибут на наличие взаимосвязей с другими реквизитами объекта. Реквизит приобретает смысл, только тогда, когда он связан с другими атрибутами, обладающими смысловым единством. 3.3 Определение отношений и мощности отношений между объектами . Рассмотрим взаимосвязи между объектами и мощности отношение и построим матрицу отношений. Страны ->Путёвки . «Страны» главный объект, а «путёвки» подчинённый объект. Тип связи «один ко многим». Так как в одну страну может быть несколько путёвок. Связь между этими объектами осуществляет атрибут «код_страны» Транспорт ->Путёвки . «Транспорт» главный объект, а «путёвки» подчинённый объект. Тип связи «один ко многим». Один транспорт может использоваться для переезда по нескольким путёвкам. Связь между этими объектами осуществляет атрибут «код_транспорта» ТурПутёвки ->ОформлениеПутёвки . «ТурПутёвки» главный объект, а «оформление путёвки» подчинённый объект. Тип связи «один ко многим». Один тур может быть оформлен несколько раз. Связь между этими объектами осуществляет атрибут «номер_тура»
И так описываются все отношения предметной области. Составим матрицу смежности для рассматриваемой предметной области. По строкам и столбцам записываем выделенные объекты предметной области. Если между объектами существуют отношения, то на пересечении строки и столбца ставится мощность отношения. Если объекты не взаимодействуют, то указывается 0. Таблица 4. Матрица смежности.
3.4 Построение схемы концептуальной модели . На основе полученных объектов, атрибутов объектов и отношений между ними, можно построить концептуальную модель. Часть 1
Рис 1 . Концептуальная модель часть1 Рис 1
.
Концептуальная модель часть2 Логическая структура реляционной базы данных определяется совокупностью логически связанных реляционных таблиц. Логические связи соответствуют структурным связям между объектами в концептуальной модели, каждый объект в логической модели отображается соответствующей реляционной таблицей. Связи между таблицами осуществляются посредством общих атрибутов. Логическая структура реляционной базы данных имеет вид: Рис 3 . Логическая структура реляционной базы 5. Реляционная модель. Вначале раздела приводится теоретическая информация о реляционной модели. Реляционная модель проектируемой базы данных: Клиенты (Код клиента , ФИО) Сотрудники ( Код сотрудника , ФИО, код фирмы) Внешний ключ: код фирмы Страны ( Код страны , название страны) Транспорт (код транспорта , вид транспорта) Путевки (№ тура , Код страны, Начало тура, Окончание тура, Код транспорта, Стоимость, Кол-во путевок) Внешний ключ: Код страны Внешний ключ: Код транспорта Оформление путёвки (№ путёвки , Код клиента, Код сотрудника, № тура, Оплата) Внешний ключ: Код клиента Внешний ключ: Код сотрудника Санаторий (санаторий , адрес, город) Заболевания (заболевание ) Заболнвание_и_санаторий (санаторий , заболевание ) Путёвки в санаторий (код поступления , санаторий, дата прибытия, продолжительность, кол-во путёвок) Внешний ключ: санаторий Оформление путёвки в санаторий (№ путёвки , код клиента, код сотрудника, код поступления, оплата) Внешний ключ: код клиента Внешний ключ: код сотрудника Внешний ключ: код поступления 6. Определение типов данных в заданном формате Таблица «Клиенты» Содержит информацию о клиентах, приобретавших путёвки. Таблица 5 Структура таблицы данных «Клиент»
Таблица «Сотрудники» Содержит информацию о сотрудниках, работающих на фирме. Таблица 6 Структура таблицы данных «Сотрудники »
7. Создание глобальной схемы связей. Поддержка целостности данных. Раздел содержит теоретические сведения: о глобальной схеме данных, о поддержании ссылочной целостности, о добавлении данных в подчинённую таблицу. Рис 4 . Схема данных. 8. Запросы. Структура и назначение. SQL – запрос Вначале раздела приводятся теоретические сведения о запросах, типах запросов, конструкторе запросов. Далее описываются все запросы информационной системы. Запрос «Количество путёвок клиента» Запрос отображает информацию о количестве путёвок, приобретённых каждым клиентом Запрос создан на основе таблиц «Оформление путёвки», «Клиенты» Рис 5 Структура запроса «Количество путёвок клиента» Запрос в режиме SQL: SELECT клиенты.ФИО, Count([оформление путевки].[№ тура]) AS [Count-№ тура] FROM клиенты INNER JOIN [оформление путевки] ON клиенты.[Код клиента] = [оформление путевки].[Код клиента] GROUP BY клиенты.ФИО; Запрос «Неоплаченные туры» Запрос отображает информацию о клиентах, не оплативших путёвки. Запрос построен на основе таблиц «Оформление путёвки», «путёвки» Рис 6 Структура запроса «Неоплаченные туры» Запрос в режиме SQL SELECT [оформление путевки].[Код клиента], [оформление путевки].[№ тура], [оформление путевки].Оплата, путёвки.[Название тура], путёвки.Стоимость FROM путёвки INNER JOIN [оформление путевки] ON путёвки.[№ тура] = [оформление путевки].[№ тура] WHERE ((([оформление путевки].Оплата)="Не оплачено")); 9. Проектирование форм. Структура и назначение существующих форм. Access предоставляет широкие возможности для конструирования форм – графического и диалогового интерфейса пользователя. Формы являются основой разработки диалоговых приложений. Приведите теоретические сведения о разработке форм с помощью конструктора и мастера . Рассмотрим формы, спроектированные в данной базе. Форма «Клиенты» Форма создана для просмотра клиентов и приобретённых ими путёвок. Также можно оформит новую путёвку для клиента, нажав кнопку «Оформить путёвку» Данная форма состоит из основной части, где отображаются поля из таблицы «клиенты» и подчинённой, где отображаются поля из таблицы «оформление путёвок» Рис 7. Структура подчинённой формы Для перемещения по записям клиентов используются кнопки Форма «Оформление путёвки» Форма создана для формирования новой записи о приобретении клиентом путёвки. Рис 8 Структура формы «Оформление путёвки» Поле 1- «№ путёвки» заполняется автоматически на основе запроса «максимальный номер путёвки_2». Поле не редактируется пользователем. Поле 2 - поле со списком «ФИО» формируется на основе таблицы «клиенты». Оно позволяет выбрать фамилию клиента, для которого оформляется путёвка. Поле 3 - поле со списком «Название тура» формируется на основе запроса «с количеством больше 0». Оно позволяет выбирать туры, для которых количество путёвок больше 0. Поле 4- поле со списком «ФИО» формируется на основе таблицы «сотрудники». Оно позволяет выбрать фамилию сотрудника, который оформляет путёвку Поле 5 со списком «оплата» формируется на основе на основе фиксированного набора значений: Оплачен, НЕ оплачено. В примечании формы находится кнопка, которая запускает макрос «Уменьшить количество путёвок». После нажатия на кнопку пользователю будет предложено изменить данные. В случае согласия добавляется новая запись в таблицу «оформление путёвок» и уменьшается количество путёвок в туре на 1. Форма «Путёвки» Форма создана только для просмотра туров. Форма содержит следующие поля: Рис 9 Структура формы «Путёвки» В поле 1 выбирается из списка страна. Поле 2 предназначено для ввода даты начала тура. Поле 3 предназначено для ввода количества дней тура. Поле 4 предназначено для ввода номера тура. Поле 5 предназначено для ввода названия тура. В поле 6 выбирается из списка транспорт тура. Поле 5 предназначено для ввода стоимости тура. Поле 8 предназначено для ввода количества путёвок. Кнопки 9, 10 выполняют движение по записям. Кнопка 11 позволяет просмотреть отчёт ‘Туры’ Кнопка 12 предназначена для закрытия формы. 10. Структура отчетов. Средства разработки отчётов в Access предназначены для создания макета отчёта, по которому может быть осуществлён вывод данных в виде выходного печатного документа. Эти средства позволяют создавать отчёт сложной структуры, обеспечивающий вывод взаимосвязанных данных из многих таблиц, запросов, их группировку, вычисление итоговых данных. Приведите теоретические сведения о отчётах . При помощи мастера созданы следующие отчеты. Отчёт «Не оплаченные путёвки» Отчёт создан на основе запроса «Не оплаченные туры». Он отображает информацию о путевках, которые не были оплачены клиентами. Отчёт содержит разделы: заголовок отчёта, верхний колонтитул, нижний колонтитул, область данных. Верхний колонтитул содержит надписи полей: клиенты, № тура, оплата, стоимость. Область данных содержит поля запроса: код клиента, № тура, оплата, стоимость. Нижний колонтитул содержит функцию для определения даты и номера страницы Рис 10 Вид отчёта в конструкторе «неоплаченные путёвки» 11. Макросы. Назначение и алгоритм работы. Макрос представляет набор макрокоманд, который создается для автоматизации часто выполняемых задач. Группа макросов позволяет выполнить несколько задач одновременно. Макросы могут быть полезны для автоматизации часто выполняемых задач. Приведите теоретические сведения о макросах. Макрос «Уменьшить количество путёвок» Макрос выполняет следующие действия: · добавляет запись в таблицу «оформление путёвок» - Открыть запрос «оформить путёвку» · уменьшает количество путёвок для заданного тура на 1 - Открыть запрос «уменьшить кол путёвок» · закрывает форму «оформление путёвок» Макрос с условием. Пользователю выводится сообщение, которое просит подтверждение об изменении данных. Если пользователь выбрал «Да», то выполняются перечисленные действия. Рис 11 Вид макроса «уменьшить кол путёвок» в конструкторе Макрос «условие тура» Макрос с условием. Если количество записей тура (занесено в поле формы «количество стран по запросу»), соответствующих параметрам поиска больше 0, то
Если количество записей тура равно 0, то
Рис 12 Вид макроса «условие тура» в конструкторе 12. Структура главной кнопочной формы. Распределение функций информационной системы по страницам главной кнопочной формы. Рис 13 Первая страница главной кнопочной формы 1. Сведения о турах (кнопка ‘Информация о турах’) 1.1 Новый тур. 1.2 Добавить путёвку к туру. 1.3 Оформление и возврат путёвок 1.4 Туры в страны. 1.5 Поиск тура по стране и виду транспорта. 1.6 Туры и проданные путёвки. 2. Санаторно-курортное лечение (кнопка ‘Отдых в санаториях’). 2.1 Заболевания. 2.2 Санатории. 2.3 Лечение заболеваний в санаториях. 2.4 Путёвки в санатории. 2.5 Просмотр реализованных путёвок по санаториям. 2.6 Оформление путёвки в санаторий. 3. Информация для клиентов по тур. путёвкам. ( кнопка ‘Клиенты’). 3.1 Клиенты и туры. 3.2 Неоплаченные путёвки. 3.3 Список клиентов. 4. Сотрудники. (кнопка ‘Сотрудники’). 4.1 Список сотрудников. 5. Статистика (кнопка ‘Статистика’). 5.1 Туры с просроченной датой. 5.2 Путёвки в санаторий с истекшей датой заезда. 5.3 Самый популярный тур. 5.4 Самый дешёвый тур 5.5 Наиболее частые клиенты 13. Руководство пользователя . Разработанная информационная система предназначена для структурированного хранения данных и вывода информации о турах по странам, путёвках туров, клиентах. Для работы с представленной базой данных необходимы:
3. Microsoft Access. Описание последовательности действий по реализации функций системы- Добавить новый тур Откройте главную кнопочную форму. Выберите кнопку «Информация о турах». Вы перейдёте на следующую страницу ‘Сведения о турах’ Щёлкните на кнопке «Новый тур» На экран отображается форма. После ввода информации, нажмите на кнопке с изображением дискеты. Запись будет сохранена. При выборе страны и вида транспорта используйте раскрывающийся список. - Добавить путёвки к уже существующему туру. Откройте главную кнопочную форму. Выберите кнопку «Информация о турах». Вы перейдёте на следующую страницу ‘Сведения о турах’ Щёлкните на кнопке «Добавить путёвки к туру» На экране отображается форма Рис 14 Форма «Добавить путёвки к туру» Поле 1 – позволяет выбрать наименование тура Поле 2 – предназначено для ввода количества путёвок. После заполнения полей нажмите на кнопке «Добавить путёвки к туру» Далее описываются все страницы и кнопки Главной кнопочной формы . 14. Заключение . Проделанная работа позволяет любому пользователю хранить большие объёмы информации, обрабатывать их, сортировать, делать выборки по определённым критериям. Разработанная база данных может быть использована в работе туристического бюро. 16.Графическое приложение. 16.1 Экранные формы проекта. Форма «Добавить путёвки к туру» Форма «Туры в страны» 16 .2 Отчёты Лечение заболеваний в санаториях заболевания санаторий дата продолжи количе стоимос прибыти тельность ство ть аллергия Русь 20.06.2006 20 9 20000 глаукома Пикет 20.06.2006 20 90 10000 дерматология Жемчужина 20.07.2006 10 4 0 желудочно-кишечного тракта им. 30-летия Победы 01.07.2007 21 10 22000 Центральный военный 15.07.2006 21 10 21000 санаторий ВИКТОРИЯ 20.06.2006 21 18 25000 желчекаменная болезнь Эльбрус 15.07.2006 21 25 19000 Жемчужина 20.07.2006 10 4 0 катаракта Пикет 20.06.2006 20 90 10000 ЛОР - органы Эльбрус 15.07.2006 21 25 19000 6 июня 2006 г. Страница 1 из 3 Литература. 1. Хансен Г., Хансен Дж. Базы данных: разработка и управление.-М.: ЗАО "Издательство БИНОМ", 1999, 300 с. 2. Дейт, К., Дж. Введение в системы баз данных. -СПб.: Издательский дом "Вильяме", 1999, 520 с. 3. Горев А., Ахаян Р., Макашарипов С. Эффективная работа с СУБД-СПб.:Питер, 1997, 440 с. 4. Мартин Дж. Организация баз данных в вычислительных системах.-Издательство "Мир", 1980, 600 с. 5. Киреева Е.В., Кусков А.Н. Реляционная алгебра и реляционное исчисление. Уч.пособие. 2000г., 40 с. 6. Киреева Е.В. Дореляционные модели данных. Уч.пособие. 2000 г. 35 с. 7. Киреева Е.В., Кусков А.Н. Реляционная модель. Нормализация. Уч.пособие. 2000 г. 42 с. 8. Дейт, К., Дж. Введение в системы баз данных. -СПб.: Издательский дом "Вильяме", 1999. 350 с. 9. Киреева Е.В. Физическая организация баз данных. Уч.пособие. 2001г. 10. Надеждина О.В. методические указания для студентов по выполнению практических занятий. Часть1. 2008. 11. Надеждина О.В. методические указания для студентов по выполнению практических занятий. Часть2. 2008. 12. Надеждина О.В методические указания для студентов по выполнению практических занятий. ЧастьЗ. 2008. 13. Старкова А.Ю. методические указания для студентов по выполнению практических занятий. Часть4. 2008. 14. Старкова А.Ю. методические указания для студентов по выполнению практических занятий. Частьэ. 2008. |