Вход

Базы данных/интернет

Рекомендуемая категория для самостоятельной подготовки:
Реферат*
Код 163300
Дата создания 2005
Страниц 27
Источников 9
Мы сможем обработать ваш заказ (!) 13 января в 12:00 [мск]
Файлы будут доступны для скачивания только после обработки заказа.
970руб.
КУПИТЬ

Содержание

ВВЕДЕНИЕ
АЛЬТЕРНАТИВНЫЕ ВАРИАНТЫ ИЛИ НУЖНА ЛИ САЙТУ БД?
ПРАВОВЫЕ АСПЕКТЫ
СОЦИАЛЬНО-ЭКОНОМИЧЕСКИЕ АСПЕКТЫ
ВНЕДРЕНИЕ НОВЫХ ТЕХНОЛОГИЙ
ИСТОРИЯ РАЗВИТИЯ
ОСНОВНЫЕ ПОНЯТИЯ
РЕЛЯЦИОННЫЕ БАЗЫ ДАННЫХ
СВЯЗЬ МЕЖДУ ТАБЛИЦАМИ
МЕХАНИЗМ ТРАНЗАКЦИЙ
ЯЗЫК ЗАПРОСОВ SQL
ПРОЕКТИРОВАНИЕ БАЗЫ ДАННЫХ
БЕЗОПАСНОСТЬ БАЗ ДАННЫХ
РЕЗЮМЕ
ОЦЕНКА ЭФФЕКТИВНОСТИ ИСПОЛЬЗОВАНИЯ
Литература 27

Фрагмент работы для ознакомления

Для нее удобно создать две таблицы. В первой следовало бы содержать информацию о читателях, а во второй — данные о выдаче книг, т.е. в каждую запись второй таблицы заносится информация о выдаче книги читателю и возврате книги. В данном примере главной является таблица читателей, а подчиненной — таблица выдачи книг. Если один читатель имеет на руках несколько книг, то это и будет пример связи «один ко многим», где одной записи в главной таблице соответствуют несколько записей в подчиненных.
Отношение «один к одному» возникает, когда производится разбиение начальной таблицы с очень большим количеством полей. Тогда менее используемые поля переносятся в подчиненную таблицу.
Вариант «много к одному» — это противоположность связи «один ко многим». Ситуация «много ко многим» встречается, когда одной записи главной таблицы соответствуют многие записи подчиненной и наоборот.
При работе со связанными таблицами несколько усложняются элементарные операции с ними. Скажем, при необходимости переименования или удаления записи главной таблицы следует предусмотреть действия со связанными записями подчиненной таблицы. Существуют два подхода к изменению и удалению записей главной таблицы БД:
1. Запретить удаление всех записей главной таблицы, а также изменение первичных ключей, на которые ссылаются записи подчиненных таблиц.
2. Разрешить удаление записей главной таблицы и изменение значений первичных ключей и автоматически распространять эти изменения на все соответствующие записи подчиненных таблиц; т.е. при удалении записи главной таблицы удаляются все связанные записи в подчиненной таблице; при изменении первичного ключа записи главной таблицы изменяется и внешний ключ записей, ссылающихся на нее в подчиненной.
Механизм транзакций
Мы уже говорили, что любая «хорошая» БД непременно должна быть целостной и непротиворечивой. Без выполнения этих требований она может стать непригодной для использования. Для обеспечения вышеназванных условий и предусмотрены транзакции.
Транзакция — это такая последовательность операций над БД, которую следует рассматривать как единый набор действий, как нечто целое. Следовательно, транзакция может быть завершена либо успешно (т.е. все операции будут записаны), либо неудачно, когда при возникновении недопустимой ошибки отменяются все (даже правильно выполненные) операции в составе транзакции.
Благодаря применению транзакций информация в базе данных находится в непротиворечивом и целостном состоянии до и после производимых изменений.
В каких случаях может быть необходимо применение транзакций? Представим себе такую ситуацию: у нас имеются две таблицы данных и надо переместить некоторое количество записей из одной в другую. При перемещении записи сначала копируются во вторую таблицу (таблицу-назначение), а затем они удаляются из первой (таблицы-источника).
А что если после перемещения записей внезапно случится сбой в работе компьютера и данные не удалятся? Получится, что записи скопированы в таблицу-назначение, но не удалены из таблицы-источника, т.е. мы получили не то, что нам требовалось. Вот здесь-то и поможет транзакция: начнем ее до первой операции копирования, а зафиксируем после окончания последней операции удаления. Важно только обратить внимание на то, что перед записью транзакции надо обязательно контролировать требуемые критические параметры. В нашем примере следует проверить, скопированы ли все интересующие записи во вторую таблицу и удалены ли они после этого из первой. Таким образом, мы либо проделаем в точности все те операции, которые нам необходимы, либо отменим сделанные изменения, не повредив БД.
Для реализации механизма транзакций каждая СУБД предоставляет соответствующие программные средства. Во встроенном языке 1С, например, для этого есть предопределенные системные процедуры:
НачатьТранзакцию () — открывает обработку транзакции;
ЗафиксироватьТранзакцию () — завершает успешную транзакцию;
Отменить/Транзакцию () — отменяет неудачную транзакцию, не записывая из-
менений.
Язык запросов SQL.
Любой разговор о реляционных базах данных без упоминания SQL был бы неполным.
Язык SQL (от английского Structured Query Language — язык структурированных запросов) предназначен для осуществления разнообразных действий с таблицами БД и непосредственно с данными этих таблиц. Составленную на языке SQL последовательность операторов и выражений называют SQL-запросом. Его грамматический строй максимально приближен к строю обычного английского предложения.
Существующий сегодня стандарт — это обобщение почти всех известных реализаций языка SQL. Это значит, что само ядро стандарта содержит функции, имеющиеся практически во всех известных коммерческих реализациях языка;
Сам по себе язык SQL редко используется самостоятельно. Обычно он применяется в интерактивном режиме, встраиваясь в другие средства (какую-либо оболочку). Пользователь может работать в системе управления базами данных, имеющей интерактивный интерфейс, ничего при этом не зная о языке SQL и причем база данных может быть как локальной, так и удаленной. В таких СУБД действия, связанные с программированием запросов на SQL, выполняются неявно.
Что же касается системы 1С:Предприятие, то явным образом язык SQL, в ней нигде не используется. Однако возможности языка запросов SQL реализованы достаточно широко, в частности при оптимизации выполнения расчетов, построения отчетов и т.д. (то есть это операции, связанные с обработкой большого объема информации). Существуют даже специальные версии для SQL, которые обеспечивают возможность работы с информационной базой в режиме клиент-сервер. Такой подход позволяет добиться большей устойчивости и надежности функционирования системы, а также увеличить производительность ее работы, особенно при наличии большого количества пользователей. В качестве сервера баз данных система использует Microsoft SQL Server.
Проектирование базы данных
Жизненный цикл любого программного обеспечения состоит из трех основных этапов:
• проектирование;
• реализация;
• эксплуатация.
Проектированием будем называть организацию интересующей нас структуры данных нужным нам образом (т.е. в соответствии с текущими потребностями, а также с учетом исключения дублирования информации и т.п. — см. ниже) Реализация — это: воплощение спроектированной (скажем, на бумаге) БД на компьютере с использованием СУБД. Эксплуатация — это задача пользователя БД. Она подразумевает наполнение базы данных конкретной информацией, ее обработку, выполнение запросов (извлечение информации) и другие пользовательские действия. В этой главе мы рассмотрим в основном вопросы разработки БД.
Теперь нам предстоит ближе познакомиться с процессом проектирования базы данных, выяснить, какие главные шаги следует предпринимать, какими принципами руководствоваться. Понимание этого имеет большое значение и позволит не попасть впросак, когда потребуется организовать какую-либо структуру данных.
Мы будем рассматривать проектирование БД, скажем так, «вручную». Этот «ручной» метод включает в себя сбор информации о тех объектах, которые мы собираемся хранить, в одну таблицу, а затем разбиение (декомпозицию) ее на несколько взаимосвязанных таблиц на основе нормализации отношений. Иными словами, речь идет о приведении данных к требуемой структуре.
Дело в том, что также существуют совершенно иные подходы к созданию БД или прикладных информационных систем с помощью т.н. средств СА8Е. Это специализированные средства, которые автоматизируют процесс разработки БД, а также всей информационной системы. Рассматривать данный метод мы не будем, т.к. он не представляет для нас практического интереса.
Отметим сразу, что проектирование БД на практике заключается в определении состава таблиц и связей между ними. В результате нашей работы должны быть выполнены условия:
• отсутствия повторения данных;
• целостности данных;
• по возможности быстрого доступа к данным.
Лучше всего продолжить знакомство с проектированием БД на практическом примере. Речь пойдет о таблице сотрудников, содержащей дублирование данных.
ФИО телефон Иванов А.Ф. 4730 Петров Т.Т 4730 Сидоров Т.О. 2210 Николаев А.А. 2210
Рис. 3 Пример неизбыточного дублирования
Сразу же замечаем, что в таблице, приведенной на рис. 3, для сотрудников Иванова П.С. и Петрова С.М., а также Николаева И.К. и Сидорова О.В. мы
имеем одинаковые номера телефонов, т.е. значения поля «Телефон» дублируются. Вообще-то это не очень хорошо. Данные в идеале не должны дублироваться, ведь это расходует вычислительные ресурсы компьютера на их обработку, занимает память, время и т.д.
Но давайте задумаемся, всегда ли можно избавиться от дублирования данных? Попробуйте как-нибудь сократить лишнюю информацию в таблице, приведенной на рис. 3. Скажем сразу, что это невозможно. Если мы попытаемся, например, для сотрудника Петрова С.М. удалить телефон, заменив его, скажем, прочерком то, на первый взгляд, мы решаем проблему (рис. 4).
ФИО телефон Иванов А.Ф. 4730 Петров Т.Т - Сидоров Т.О. 2210 Николаев А.А. - Рис. 4. Пример неудачного устранения дублирования
Зато теперь нам придется дополнительно программировать методы поиска информации, к которой относится тот или иной прочерк, предусматривать процесс удаления из таблицы тех записей, где прочерков нет (дело в том, что на такие записи могут ссылаться какие-либо прочерки) и т.д. Кроме того, мы вообще не сократим объем таблицы. Память все равно резервируется для каждого поля любой записи, и неважно, что мы вносим прочерки, а не номера телефонов. Таким образом, мы не решили имеющуюся проблему, а дополнительно создали другую.
Делаем вывод, что от дублирования данных можно избавиться не всегда. Ситуация, показанная на рис. 4, называется неизбыточным дублированием данных. Оно является вполне естественным и допустимым (под избыточностью понимают такое состояние данных в системе, при котором часть их можно исключить, не потеряв нужных сведений). В нашем же случае ничего исключить нельзя.
Существует, однако, еще и избыточное дублирование данных — такое, от которого можно и нужно избавиться. Расширим предыдущий пример.
Очевидно, что сотрудники, которые находятся в одной комнате, имеют один и тот же номер телефона. Мы вновь сталкиваемся с дублированием: повторяются и номера комнат, и телефоны (рис. 5). Если попытаться и на этот раз заменить повторы телефонов прочерками, то все проблемы, с которыми мы столкнулись при прошлой попытке, останутся.
ФИО комната телефон Иванов А.Ф. 1 4730 Петров Т.Т 1 4730 Сидоров Т.О. 2 2210 Николаев А.А. 2 2210
Рис. 5. Избыточное дублирование данных
Правильный способ устранения избыточности — разбиение таблиц. Для таблицы рис. 5 оно примет вид:
Рис. 6 Исключение избыточного дублирования путем разбиения таблиц
В приведенной на рис. 6 структуре данных для получения номера телефона сотрудника мы обращаемся к главной таблице (вернее, обращается компьютер), находим строку с данными о нужном сотруднике, считываем номер его комнаты, переходим в подчиненную таблицу, находим искомую строку по нужному номеру и, наконец, узнаем номер телефона.
Приведенное выше разбиение таблицы на связанные — пример процесса нормализации отношений. Отметим также, что такое разбиение имеет недостаток, заключающийся в том, что немного увеличивается время доступа к БД вследствие необходимости работать с несколькими таблицами данных вместо одной.
Теперь приведем минимальный объем теоретических сведений. Метод нормализации отношений базируется на достаточно сложной теории реляционных моделей БД. Затронем лишь самые важные моменты.
Нормализация является итерационным процессом. Существует пять «нормальных» форм. Каждая последующая итерация (т.е. этап нормализации, нормальная форма), образно говоря, устраняет все больше недостатков и делает структуру БД еще более оптимизированной. На практике обычно используют три
первые формы (НФ). Каждая последующая НФ удовлетворяет всем требованиям предыдущих НФ и добавляет свои. Итак, сами формы:
1. Первая НФ требует выполнения условий: а) поля содержат неделимую информацию, б) в таблице нет повторяющихся групп полей. Следовательно, приведение таблицы к первой НФ заключается в устранении повторяющихся групп полей.
2. Вторая НФ удаляет частичнозависимые атрибуты, т.е. удовлетворяет условиям первой НФ и, кроме того, требует, чтобы любое неключевое поле однозначно идентифицировалось ключевым.
3. Третья НФ удаляет транзитивно зависимые атрибуты, т.е. ни одно из неключевых полей не может однозначно определяться значением другого неключевого поля.
Подводя итог всему сказанному, приведем условный алгоритм проектирования БД:
1. Определить информационные потребности БД.
2. Проанализировать объекты реального мира, отражаемые в БД. Выделить их свойства, которые предстоит систематизировать в таблице (таблицах) базы данных.
3. Оформить свойства, выясненные на втором этапе, в виде полей таблиц.
4. Определить атрибуты, которые уникально определяют каждый объект. Создать все необходимые ключи и индексы.
5. Выработать правила по поддержанию целостности данных.
6. Установить связи между таблицами (столбцами) и провести нормализацию таблиц.
7. Продумать вопросы надежности данных и, при необходимости, секретности информации.
В целом мы завершили знакомство с проектированием БД. Обратите внимание на его важность. Именно на этапе проектирования закладываются основные свойства всей информационной системы, ее функциональные возможности. Проектирование для наглядности можно сравнить с фундаментом. Качеством проектирования определяется качество информационной системы, а также ее расширяемость для новых требований заказчика. Что же касается проектирования информационных структур в рамках 1С, то здесь тоже очень важно прежде, чем приступать непосредственно к разработке, тщательно продумать сущность задач, стоящих перед заказчиком. Затем нужно выработать целостное видение — план будущей информационной системы.
Безопасность баз данных
Прежде чем завершить введение в базы данных, необходимо коснуться вопроса безопасности БД.
Как уже говорилось выше, таблицы БД — это, как правило, отдельные файлы. Мы обязательно с ними столкнемся при работе с 1С. Но файлы таблиц БД обладают особенностями, вызванными требованиями к безопасности.
Вы не могли не заметить при работе с прикладными программами, что сохранение данных во внешней памяти (обычно на винчестере) происходит интерактивно: будь то выбор соответствующей команды меню, ответ на запрос программы при ее закрытии, периодическое автосохранение и т.д. При работе с таблицами баз данных все совершенно иначе. В ходе внесения изменений в содержание данных таблицы БД происходит мгновенное автоматическое сохранение изменений в самой таблице, т.е. на жестком диске. В случае таблиц БД мы как бы работаем напрямую с винчестером, в отличие от прикладных программ (например, текстовых процессоров, графических пакетов и т.д.), которые все изменения, сделанные в тех или иных документах, сначала сохраняют в оперативной памяти компьютера.
Для нас сейчас важно запомнить, что любые изменения данных сохраняются сразу, Причем обратите внимание, что не имеются в виду изменения в структуре данных. Операции, связанные с сохранением реструктурированной БД, осуществляются по-прежнему интерактивно.
Резюме
Реляционная модель данных в настоящее время распространена наиболее широко. База данных, построенная на основе этой модели, представляет собой набор функционально взаимосвязанных таблиц данных.
Связь между главной и подчиненной таблицами организуется при помощи ключей и индексов. Кроме того, использование ключей и индексов позволяет нам: однозначно идентифицировать записи, избегать дублирования значений в ключевых полях, выполнять сортировку таблиц, ускорять операции поиска в таблицах, устанавливать связи между отдельными таблицами БД, использовать ограничения ссылочной целостности.
Для поддержания целостности БД применяется механизм транзакций, который позволяет гарантировать целостность и непротиворечивость информации в базе в случае успешного завершения транзакции (в случае же какого-либо сбоя все проделанные с БД действия отменяются).
Проектирование БД можно рассматривать как последовательность шагов. Проектирование обязательно включает в себя нормализацию таблиц, т.е. приведение их к нормальным формам.
При работе с базами данных следует особое внимание уделять безопасности, все упражнения и опыты производить только с копиями используемых в эксплуатации БД.
Оценка эффективности использования
Представим на минутку, то в нашей жизни нет баз данных. Библиотекари и сотрудники отдела кадров вновь вернутся к картотекам. Не будет автоматизированного бухгалтерского и складского учета. Перестанут работать Интернет - программы по заказу билетов, горящих путевок, и.т.д. Что же произойдет? Да ничего – когда-то мы жили без баз данных. И все же использование баз данных существенно экономит время и облегчает жизнь современному человеку.
Литература
Абдулин А., Козленко Л. «Представление отсутствующей информации».  
Виноградов С. А. «Минимальный набор стандартных таблиц».
Виноградов С. А. «Перечисляемый тип в базе данных». 
. Тенцер А. «Естественные ключи против искусственных ключей» 
Дейт К. «Введение в системы баз данных». Издание шестое, Диалектика, Киев — Москва, 1998.
Марков Б. «Проектирование систем регистрации и анализа данных».
Попов А.А. «FoxPro 2.5/2.6»
Тенцер А. «База данных — хранилище объектов».
Усиков Т.Н. «1С: предприятие. Эффективное программирование»

Список литературы [ всего 9]

1.Абдулин А., Козленко Л. «Представление отсутствующей информации».
2.Виноградов С. А. «Минимальный набор стандартных таблиц».
3.Виноградов С. А. «Перечисляемый тип в базе данных».
4.. Тенцер А. «Естественные ключи против искусственных ключей»
5.Дейт К. «Введение в системы баз данных». Издание шестое, Диалектика, Киев — Москва, 1998.
6.Марков Б. «Проектирование систем регистрации и анализа данных».
7.Попов А.А. «FoxPro 2.5/2.6»
8.Тенцер А. «База данных — хранилище объектов».
9.Усиков Т.Н. «1С: предприятие. Эффективное программирование»
Очень похожие работы
Найти ещё больше
Пожалуйста, внимательно изучайте содержание и фрагменты работы. Деньги за приобретённые готовые работы по причине несоответствия данной работы вашим требованиям или её уникальности не возвращаются.
* Категория работы носит оценочный характер в соответствии с качественными и количественными параметрами предоставляемого материала. Данный материал ни целиком, ни любая из его частей не является готовым научным трудом, выпускной квалификационной работой, научным докладом или иной работой, предусмотренной государственной системой научной аттестации или необходимой для прохождения промежуточной или итоговой аттестации. Данный материал представляет собой субъективный результат обработки, структурирования и форматирования собранной его автором информации и предназначен, прежде всего, для использования в качестве источника для самостоятельной подготовки работы указанной тематики.
bmt: 0.00461
© Рефератбанк, 2002 - 2025