независимость от конкретных СУБД;
переносимость с одной вычислительной системы на другую;
наличие стандартов;
поддержка со стороны компании Microsoft (протокол ODBC);
реляционная основа;
высокоуровневая структура, напоминающая английский язык;
возможность выполнения специальных интерактивных запросов:
обеспечение программного доступа к базам данных;
возможность различного представления данных;
полноценность как языка, предназначенного для работы с базами данных;
возможность динамического определения данных;
поддержка архитектуры клиент/сервер.
Все перечисленные выше факторы явились причиной того, что SQL стал
стандартныминструментом для управления данными на персональных компьютерах,
мини-компьютерах и больших ЭВМ. Ниже эти факторы рассмотрены более подробно.
Независимость от конкретных СУБД
Все ведущие поставщики СУБД используют SQL, и ни одна новая СУБД, не
поддерживающая SQL, неможет рассчитывать на успех. Реляционную базу данных и
программы, которые с ней работают, можно перенести с одной СУБД на другую с
минимальными доработками ипереподготовкой персонала. Программные средства,
входящие в состав СУБД для персональных компьютеров, работают с реляционными
базами данных многих типов.
Переносимость с одной вычислительной системы на другие
Поставщики СУБД предлагают программные продукты для различных вычислительных
систем: отперсональных компьютеров и рабочих станций до локальных сетей,
мини-компьютеров и больших ЭВМ. Приложения, созданные с помощью SQL и
рассчитанные наоднопользовательские системы, по мере своего развития могут быть
перенесены в более крупные системы. Информация из корпоративных реляционных баз
данных можетбыть загружена в базы данных отдельных подразделений или в личные
базы данных. Наконец, приложения для реляционных баз данных можно вначале
смоделировать наэкономичных персональных компьютерах, а затем перенести на
дорогие многопользовательские системы.
Стандарты языка SQL
Официальный стандарт языка SQL был опубликован Американским институтом
национальныхстандартов (American National Standards Institute — ANSI) и
Международной организацией по стандартам (International Standards Organization —
ISO) в 1986году и значительно расширен в 1992 году. Кроме того, SQL является
федеральным стандартом США по обработке информации (FIPS — Federal Information
ProcessingStandard) и, следовательно, соответствие ему является одним из
основных требований, содержащихся в больших правительственных контрактах,
относящихся к областивычислительной техники. В Европе стандарт X/OPEN для
переносимой среды программирования на основе операционной системы UNIX включает
в себя SQL вкачестве стандарта для доступа к базам данных. SQL Access Group —
консорциум поставщиков компьютерного оборудования и баз данных — определил для
SQLстандартный интерфейс вызовов функций, который является основой протокола
ODBC компании Microsoft и входит также в стандарт X/OPEN. Эти стандарты служат
какбы официальной печатью, одобряющей SQL, и они ускорили завоевание им рынка.
Протокол ODBC и компания Microsoft
Компания Microsoft рассматривает доступ к базам данных как важную часть
своейоперационной системы Windows. Стандартом этой компании по обеспечению
доступа к базам данных является ODBC (Open Database Connectivity —
взаимодействие соткрытыми базами данных) — программный интерфейс, основанный на
SQL. Протокол ODBC поддерживается наиболее распространенными приложениями
Windows(электронными таблицами, текстовыми процессорами, базами данных и т.п.),
разработанными как самой компанией Microsoft, так и другими ведущими
поставщиками.Поддержка ODBC обеспечивается всеми ведущими реляционными базами
данных. Кроме того, ODBC опирается на стандарты, одобренные консорциумом
поставщиков SQLAccess Group, что делает ODBC как стандартом де-факто компании
Microsoft, так и стандартом, независимым от конкретных СУБД.[13, 8, 17].
1.4.3Запрос наязыке SQL
Как подчеркивалось ранее, SQL символизирует собой Структурированный Язык
Запросов. Запросы - вероятно наиболеечасто используемый аспект SQL.
Фактически, для категории SQL пользователей, маловероятно чтобы кто-либо
использовалэтот язык для чего-то другого. Итак :
Запрос - команда которую дается прикладной программе базы данных, и которая
сообщает ейчтобы она вывела определенную информацию из таблиц в память. Эта
информация обычно посылается непосредственно на экран компьютера или
терминала хотя, в большинстве случаев, ее можно также послать принтеру,
сохранить вфайле ( как объект в памяти компьютера ), или представить как
вводную информацию для другой команды или процесса.
Одна из наиболее важных особенностей запросов SQL - это их способность
определять связимежду многочисленными таблицами и выводить информацию из них в
терминах этих связей, всю внутри одной команды. Этот вид операции называется
-объединением, которое является одним из видов операций в реляционных базах
данных.
Как установлено ранее, главное в реляционном подходе это связи которые можно
создавать между позициями данных в таблицах. Используя обьединения,
мынепосредственно связываем информацию с любым номером таблицы, и таким образом
способны создавать связи между сравнимыми фрагментами данных. При обьединении,
таблицы представленыесписком в предложении FROM запроса, отделяются запятыми.
Предикат запроса может ссылаться к любому столбцу любой связанной таблицы и,
следовательно, может использоваться длясвязи между ими.
Язык допускает три типа синтаксических конструкций, начинающихся с ключевого
слова SELECT:спецификация курсора (cursor specification), оператор выборки
(select statement) и подзапрос (subquery). Основой всех них является
синтаксическаяконструкция "табличное выражение (table expression)". Семантика
табличного выражения состоит в том, что на основе последовательного
примененияразделов from, where, group by и having из заданных в разделе from
таблиц строится некоторая новая результирующая таблица, порядок следования
строккоторой не определен и среди строк которой могут находиться дубликаты (т.е.
в общем случае таблица-результат табличного выражения является
мультимножествомстрок). На самом деле именно структура табличного выражения
наибольшим образом характеризует структуру запросов языка SQL/89.
1.4.4Агрегатные функции
Запросы могут производить обобщенное групповое значение полей точно также как и
значениеодного поля. Это делает с помощью агрегатых функций. Агрегатные функции
производят одиночное значение для всей группы таблицы. Имеется список
этихфункций:
COUNT производит номера строк или не-NULL значения полей которые выбрал
запрос.
SUM производит арифметическую сумму всех выбранных значений данного поля.
AVG производит усреднение всех выбранных значений данного поля.
MAX производит наибольшее из всех выбранных значений данного поля.
MIN производит наименьшее из всех выбранных значений данного поля.
1.5Локальные вычислительныесети
На сегодняшний день в мире существует более 150 миллионов компьютеров, более 80
% из них объединеныв различные информационно-вычислительные сети от малых
локальных сетей в офисах до глобальных сетей типа Internet
Автоматизированное рабочее место «Отдел Кадров» является программой, активно
использующей сетевоесоединение отдельных компьютеров в локальную вычислительную
сеть. Только при этом становится возможной передача информации с любого рабочего
места пользователя на сервер и обратно. Скоростьпередачи данных по сети
естественным образом влияет на общую скорость работы всего АРМ. В свою очередь,
скорость прохождения информации от сервера клокальному компьютеру пользователя
определяется комплексом программно-аппаратных средств, которые и составляют
локальную вычислительнуюсеть.
В настоящее время существуют различные способы связи разрозненных компьютеров в
единоецелое (т.е. в сеть). Спектр аппаратных средств (и программных для
управления ими) более чем широк. Иногда это приводит к некоторому затруднению
при выборетипа сети и её программного обеспечения. Неправильный выбор может в
дальнейшем привести к невозможности функционирования программ в случае
увеличения паркамашин или возрастания требований к скорости и объемам
передаваемой информации. С учетом сказанного становится ясно, что необходимо в
достаточной степенипонимать принципы организации ЛВС, грамотно выбрать
аппаратные и программные средства для её построения.
В данном разделе описаны основные, базовые принципы ЛВС, приведены различные
схемы соединения машин. Дано описаниедостоинств и недостатков каждой схемы.
Теоретическая информация подкреплена описанием реально используемыми в настоящее
время аппаратными и программнымисредствами для построения ЛВС. Наряду с давно
применяемыми и хорошо изученными способами построения сетей приводится описание
современного способа соединенияс помощью оптоволоконного кабеля.
1.5.1Файл сервер и рабочие станции
ЛВС могут состоять из одного файл-сервера, поддерживающего небольшое число
рабочих станций, или из многих файл-серверов и коммуникационных серверов,
соединенных с сотнями рабочих станций. Некоторые сетиспроектированы для
оказания сравнительно простых услуг, таких, как совместное пользование
прикладной программой и файлом и обеспечение доступа к единственному
принтеру. Другие сети обеспечивают связь с большими и мини-ЭВМ, модемами
коллективного пользования, разнообразными устройствами
ввода/вывода(графопостроителями, принтерами и т. д.) и устройствам памяти
большой емкости (диски типа WORM).
Файл-сервер является ядром локальной сети. Этот компьютер (обычно