МЕНЮ


Фестивали и конкурсы
Семинары
Издания
О МОДНТ
Приглашения
Поздравляем

НАУЧНЫЕ РАБОТЫ


  • Инновационный менеджмент
  • Инвестиции
  • ИГП
  • Земельное право
  • Журналистика
  • Жилищное право
  • Радиоэлектроника
  • Психология
  • Программирование и комп-ры
  • Предпринимательство
  • Право
  • Политология
  • Полиграфия
  • Педагогика
  • Оккультизм и уфология
  • Начертательная геометрия
  • Бухучет управленчучет
  • Биология
  • Бизнес-план
  • Безопасность жизнедеятельности
  • Банковское дело
  • АХД экпред финансы предприятий
  • Аудит
  • Ветеринария
  • Валютные отношения
  • Бухгалтерский учет и аудит
  • Ботаника и сельское хозяйство
  • Биржевое дело
  • Банковское дело
  • Астрономия
  • Архитектура
  • Арбитражный процесс
  • Безопасность жизнедеятельности
  • Административное право
  • Авиация и космонавтика
  • Кулинария
  • Наука и техника
  • Криминология
  • Криминалистика
  • Косметология
  • Коммуникации и связь
  • Кибернетика
  • Исторические личности
  • Информатика
  • Инвестиции
  • по Зоология
  • Журналистика
  • Карта сайта
  • АРМ бухгалтера Учет основных средств

    курсор - это не копия некоторых данных, помещаемая в другую таблицу. Когда

    изменяются данные в виртуальной таблице, то тем самым изменяются данные в

    базовых таблицах. Подобно результатам операции выбора, курсоры напоминают

    обычные таблицы баз данных.

    Если применить операцию выбора к виртуальной таблице, то можно

    увидеть результаты выполнения запроса, на основе которого она была создана.

    В идеальной реляционной системе с курсорами можно оперировать, как и с

    любыми другими таблицами. В реальном мире различные версии реляционных баз

    данных накладывают на курсоры определенные ограничения, в частности на

    обновление. Одно из правил Кодда гласит, что в истинно реляционной системе

    над курсорами можно выполнять все «теоретически» возможные операции.

    Большинство современных систем управления реляционными базами данных не

    удовлетворяют этому правилу полностью.

    14.6 Нули

    В реальном мире управления информацией данные часто являются

    неизвестными или неполными: клиент не предоставил данных о физическом

    адресе организации, счет может быть оформлен, но дата его оплаты еще может

    быть неизвестна. Такие пропуски информации создают «дыры» в таблицах.

    Проблема, конечно, состоит не в простой неприглядности подобных дыр.

    Опасность состоит в том, что из-за них база может стать противоречивой.

    Чтобы сохранить целостность данных в реляционной модели, так же, как и в

    правилах Кодда, для обработки пропущенной информации используется понятие

    нуля. «Нуль» не означает пустое поле или обычный математический нуль. Он

    отображает тот факт, что значение неизвестно, недоступно или неприменимо

    [4]. Существенно, что использование нулей инициирует переход с двухзначной

    логики (да/нет или что-то/ничего) на трехзначную (да/нет/может быть или что-

    то ничего не уверен).

    С точки зрения другого эксперта по реляционным системам, Дейта, нули

    не являются полноценным решением проблемы пропусков информации. Тем не

    менее, они являются составной частью большинства официальных стандартов SQL

    и de facto промышленных стандартов.

    14.7 Безопасность

    Понятие безопасности связано с необходимостью управления доступом к

    информации. Определенные команды позволяют некоторым привилегированным

    пользователям устанавливать права других пользователей на просмотр и

    модификацию информации в базе данных. В большинстве реализаций реляционных

    баз данных правами на доступ и модификацию данных (permission) можно

    управлять на уровне таблиц и столбцов. Эти права устанавливают владельцы

    (owner) баз данных или объектов баз данных. Некоторые системы разрешают

    передавать права владения от создателя базы другому пользователю.

    В многопользовательских системах обычно имеется пользователь с

    правами даже более высокими, чем у владельца базы данных - системный

    администратор (system administrator), или администратор базы данных

    (database administrator). Этот пользователь обычно обладает широкими

    правами на наделение полномочий, а также выполняет целый ряд других задач,

    связанных с поддержкой и администрированием базы данных.

    В качестве дополнительного механизма обеспечения безопасности могут

    выступать и виртуальные таблицы. Пользователи могут разрешать доступ только

    к определенному подмножеству своих данных, включенному в виртуальную

    таблицу.

    14.8 Целостность

    Целостность (integrity) - очень сложный и серьезный вопрос при

    управлении реляционными базами данных. Несогласованность между данными

    может возникать по целому ряду причин. Несогласованность или

    противоречивость данных может возникать вследствие сбоя системы - проблемы

    с аппаратным обеспечением, ошибки в программном обеспечении или логические

    ошибки в приложениях. Реляционные системы управления базами данных

    защищают данные от такого типа несогласованности, гарантируя, что команда

    либо будет исполнена до конца, либо будет полностью отменена. Этот процесс

    обычно называют управлением транзакциями (transaction management).

    Другой тип целостности, называемый объектной целостностью (entity

    integrity), связан с корректным проектированием базы данных. Объектная

    целостность требует, чтобы ни один первичный ключ не имел нулевого

    значения. Третий тип целостности, называемый ссылочной целостностью

    (referential integrity), означает непротиворечивость между частями

    информации, повторяющимися в разных таблицах. Например, если вы изменяете

    неправильно введенный номер расчетного счета покупателя в одной таблице,

    другие таблицы, содержащие эту же информацию, продолжают ссылаться на

    старый номер, поэтому вы должны обновить и эти таблицы. Чрезвычайно важно,

    чтобы при изменении информации в одном месте, она соответственно изменялась

    и во всех других местах [2]. Правила Кодда гласят, что системы управления

    реляционными базами данных должны обеспечивать не только объектную и

    ссылочную целостность, но и позволять «вводить дополнительные ограничения

    на целостность, отражающие специальные требования». Кроме того, по

    определению Кодда, ограничения на целостность должны:

    - определяться на языке высокого уровня, используемом системой для

    всех других целей;

    - храниться в словаре данных, а не в программных приложениях.

    Первоначально только несколько реализаций реляционных баз данных

    удовлетворяли критериям Кодда на целостность, но ситуация постепенно

    изменялась. Стандарт 1992 года (часто называемый «SQL92») поддерживает

    ограничения, обеспечивающие ссылочную целостность и позволяющие задавать

    бизнес правила. Эти возможности в том или ином виде реализованы в

    большинстве систем.

    15 Проектирование баз данных

    Процесс, в ходе которого решается, какой вид будет у вновь

    создаваемой базы данных, называется проектированием базы данных (database

    design). Работа по проектированию базы данных включает выбор:

    - таблиц, которые будут входить в базу данных;

    - столбцов, принадлежащих каждой таблице;

    - взаимосвязей между таблицами и столбцами.

    Конструирование базы данных связано с построением ее логической

    структуры. В реляционной модели логическая структура базы абсолютно не

    зависит от ее физической структуры и способа хранения. Логическая структура

    также не определяется тем, что видит у себя на экране конечный пользователь

    (это могут быть виртуальные таблицы, созданные разработчиком или

    прикладными программами).

    Конструирование баз данных на основе реляционной модели имеет ряд

    важных преимуществ перед другими моделями.

    1. Независимость логической структуры от физического и пользовательского

    представления.

    2. Гибкость структуры базы данных - конструктивные решения не

    ограничивают возможности выполнять в будущем самые разнообразные

    запросы.

    Так как реляционная модель не требует описания всех возможных связей

    между данными, можно впоследствии задавать запросы о любых логических

    взаимосвязях, содержащихся в базе, а не только о тех, которые планировались

    первоначально.

    С другой стороны, реляционные системы не имеют никаких встроенных

    защитных механизмов против некорректных структурных решений и не умеют

    различать хорошую структуру базы данных от посредственной. К тому же не

    существует автоматизированных средств, которые могли бы заменить вас в

    процессе принятия структурных решений.

    15.1 Подход к проектированию базы данных

    Часто при обсуждении вопросов проектирования реляционных баз данных

    почти все внимание уделяется применению правил нормализации. В ходе

    нормализации обеспечивается защита целостности данных путем устранения

    дублирования данных. В результате таблица, которая первоначально казалась

    «имеющей смысл», разбивается на две или более связанных таблиц, которые

    могут быть «собраны вместе» с помощью операции объединения. Этот процесс

    называется декомпозицией без потерь (non-loss decomposition) и просто

    означает разделение таблицы на несколько меньших таблиц без потери

    информации. Нормализация наиболее полезна для проверки созданной вами

    структуры. Можно проанализировать свои решения о том, какие столбцы должны

    быть включены в ту или иную таблицу с точки зрения правил нормализации,

    убедившись при этом, что не сделали каких-то фатальных ошибок. Понимание

    основ процесса нормализации также может помочь в процессе проектирования

    базы данных, но оно не является универсальным рецептом при построении базы

    с нуля. Итак, как определить, какие столбцы должны располагаться в начале

    таблицы. Общего правила на этот счет не существует. Однако здесь вам может

    оказать существенную помощь моделирование зависимостей - анализ сущности

    данных (в терминах объектов или вещей) и зависимостей между ними (один-к-

    одному, один-ко-многим, многие-ко-многим).

    На практике проектирование базы данных требует хорошего понимания

    моделируемой предметной области, а также знаний в области моделирования

    зависимостей и нормализации. Проектирование базы данных обычно является

    итеративным процессом, в ходе которого шаг за шагом достигается требуемый

    результат, а иногда и пересматривается несколько шагов, переделывая

    предыдущую работу с учетом появившихся новых потребностей. Вот примерная

    последовательность шагов, выполняемая в процессе проектирования базы

    данных.

    1. Исследования информационной среды для моделирования.

    - Откуда поступает информация и в каком виде?

    - Как она будет вводиться в систему, и кто этим будет заниматься?

    - Как часто она изменяется?

    - Какие параметры системы будут наиболее критическими с точки

    зрения времени реакции на запрос и надежности?

    - Изучение всех бумажных материалов, а также информационных файлов

    и форм, которые используются в организации для хранения и

    обработки данных.

    - Уточнение, в каком виде информация должна извлекаться из базы

    данных - в форме отчетов, заказов, статистической информации.

    - Кому она будет предназначаться.

    2. Создание списка объектов (вещей, которые будут предметом базы

    данных) вместе с их свойствами и атрибутами. Объекты, скорее всего, должны

    быть собраны в таблицы (каждая строка таблицы будет описывать один объект,

    например организацию, счет или платежное поручение), свойства объектов

    будут представлены столбцами таблицы (например, адрес компании, стоимость

    дистрибутива).

    3. В ходе работы обязательно должен создаваться макет таблиц и связей

    между ними, называемый структурой данных (data structure), или диаграммой

    зависимостей между объектами (E-R diagram).

    4. Предварительно разобравшись с объектами и их атрибутами, надо

    убедится, что каждый объект имеет атрибут (или группу атрибутов), по

    которому однозначно можно идентифицировать любую строку в будущей таблице.

    Этот идентификатор обычно называется первичным ключом. Если такового нет,

    то для получения искусственного ключа следует создать дополнительный

    столбец.

    5. Затем должны быть рассмотрены зависимости между объектами.

    - Имеются ли зависимости типа один-ко-многим (один заказчик может

    иметь множество выписанных счетов, но каждый счет может быть

    выписан только на одного заказчика) или многие-ко-многим?

    - Есть ли возможности для объединения связанных таблиц? Для этого

    служат внешние ключи (foreign key), столбцы в связанных таблицах

    с совпадающими значениями первичных ключей.

    6. Анализ структуры базы данных с точки зрения правил нормализации

    для поиска логических ошибок. Исправление всех отклонений от нормальных

    форм или обоснование решения отказаться от выполнения ряда правил

    нормализации в интересах простоты освоения или производительности.

    Документирование причины таких решений.

    7. Непосредственному создание структуры базы данных и помещению в нее

    некоторых прототипов данных. Обязательное экспериментирование с запросами,

    изучение полученных результатов. Выполнение рядов тестов на

    производительность, чтобы проверить разные технические решения.

    8. Оцените базы данных с точки зрения того, удовлетворяют ли

    заказчика полученные результаты.

    15.2 Несколько слов о структуре базы данных

    1. Что такое «хорошая структура» - это, в первую очередь,

    «прозрачная» структура. Проще говоря, хорошая структура:

    - максимально упрощает взаимодействие с базой данных;

    - гарантирует непротиворечивость данных;

    - «выжимает» максимум производительности из системы.

    Некоторые факторы, упрощающие понимание базы данных, не имеют строгих

    технических определений и не являются частью процесса проектирования. Тем

    не менее, широкие таблицы трудно читать и в них сложно разбираться. В то же

    время разделение данных на целый ряд небольших таблиц усложняет

    отслеживание взаимосвязей между ними. Выбор подходящего числа столбцов

    обычно является компромиссом между простотой понимания базы и правилами

    нормализации. Хорошо разработанная база данных предотвращает ввод

    противоречивой информации и случайное удаление данных. Это достигается за

    счет минимизации ненужного дублирования данных в таблицах и поддержки

    целостности.

    Наконец, хорошо разработанная база должна обладать достаточной

    производительностью. Опять-таки здесь играет большую роль число столбцов в

    таблицах: выборка данных будет проводиться медленнее, если информация

    размешена не в одной, а в нескольких таблицах. Однако большие таблицы могут

    требовать от системы обработки большего количества данных, чем это на самом

    деле необходимо для выполнения конкретного запроса. Другими словами,

    количество и размер таблиц существенно влияют на производительность. (Также

    с точки зрения производительности критическим является выбор столбца, по

    которому выполняется индексирование и тип индексирования.) Индексирование в

    большей мере является вопросом физического проектирования, нежели

    логического.

    2. Плохая структура базы данных

    - приводит к непониманию результатов выполнения запросов;

    - повышает риск введения в базу данных противоречивой информации;

    - порождает избыточные данные;

    - усложняет выполнение изменений структуры созданных ранее и уже

    заполненных данными таблиц.

    Не существует идеального решения, полностью удовлетворяющего все

    требования, предъявляемые при проектировании баз данных. Часто приходится

    чем-то жертвовать, основываясь на требованиях и особенностях приложений,

    которые будут использовать базу данных.

    15.3 Нормализация

    Вообще говоря, нормализация - это набор стандартов проектирования

    данных, называемых нормальным и формами (normal forms). Общепринятыми

    считаются пять нормальных форм, хотя их было предложено значительно больше.

    Создание таблиц в соответствии с этими стандартами называется

    нормализацией. Нормальные формы изменяются в порядке от первой до пятой.

    Каждая последующая форма удовлетворяет требованиям предыдущей формы. Если

    следовать первому правилу нормализации, то данные будут представлены в

    первой нормальной форме. Если данные удовлетворяют третьему правилу

    нормализации, они будут находиться в третьей нормальной форме (а также в

    первой и второй формах).

    Выполнение правил нормализации обычно приводит к разделению таблиц на

    две или больше таблиц с меньшим числом столбцов, выделению отношений

    первичный ключ - внешний ключ в меньшие таблицы, которые снова могут быть

    соединены с помощью операции объединения.

    Одним из основных результатов разделения таблиц в соответствии с

    правилами нормализации является уменьшение избыточности данных в таблицах.

    При этом в базе возможно возникновение одинаковых столбцов первичных и

    внешних ключей. Такое преднамеренное дублирование - это не то же самое, что

    избыточность. На самом деле поддержка непротиворечивости между первичными и

    внешними ключами связана с понятием целостности данных.

    Правила нормализации, подобно принципам объектного моделирования,

    развивались в рамках теории баз данных. Большинство разработчиков баз

    данных признают, что представление данных в третьей и четвертой нормальных

    формах полностью удовлетворяет все их потребности.

    15.3.1 Первая нормальная форма

    Первая нормальная форма требует, чтобы на любом пересечении строки и

    столбца находилось единственное значение, которое должно быть атомарным.

    Кроме того, в таблице, удовлетворяющей первой нормальной форме, не должно

    быть повторяющихся групп.

    В ряде случаев объектное моделирование приводит к тем же результатам,

    так как в этом случае мы имеем отношение один-ко-многим (одна накладная -

    много позиций).

    15.3.2 Вторая нормальная форма

    Второе правило нормализации требует, чтобы любой не ключевой столбец

    зависел от всего первичного ключа. Следовательно, таблица не должна

    содержать не ключевых столбцов, зависящих только от части составного

    первичного ключа. Представление таблицы во второй нормальной форме требует,

    чтобы все столбцы, не являющиеся первичными ключами (столбцы, описывающие

    объект, но однозначно не идентифицирующие его), зависели от всего

    первичного ключа, а не от его отдельных компонентов.

    Суммируя вышесказанное, вторая нормальная форма требует, чтобы ни

    Страницы: 1, 2, 3, 4, 5, 6, 7, 8, 9, 10


    Приглашения

    09.12.2013 - 16.12.2013

    Международный конкурс хореографического искусства в рамках Международного фестиваля искусств «РОЖДЕСТВЕНСКАЯ АНДОРРА»

    09.12.2013 - 16.12.2013

    Международный конкурс хорового искусства в АНДОРРЕ «РОЖДЕСТВЕНСКАЯ АНДОРРА»




    Copyright © 2012 г.
    При использовании материалов - ссылка на сайт обязательна.