Язык SQL, как мы уже видели, предназначен для организации доступа к базам данных.
При этом предполагается, что доступ к БД может быть осуществлен в двух режимах:
в интерактивном режиме и в режиме выполнения прикладных программ (приложений).
Эта двойственность
SQL создает ряд преимуществ:
SQL действительно
является языком по работе с базами данных, но в явном виде он не является языком
программирования. В нем отсутствуют традиционные операторы, организующие циклы,
позволяющие объявить и использовать внутренние переменные, организовать анализ
некоторых условий и возможность изменения хода программы в зависимости от выполненного
условия. В общем случае можно назвать SQL подъязыком, который служит исключительно
для управления базами данных. Для создания приложений, настоящих программ необходимо
использовать другие, базовые языки программирования, в которые операторы языка
SQL будут встраиваться.
Базовыми
языками программирования могут быть языки С++, COBOL, PL/1, Pascal, PHP, Java. Существуют
два способа применения SQL в прикладных программах:
Процесс выполнения
операторов SQL может быть условно разделен на 5 этапов (см. рис. 12.1).
Рис.
12.1. Процесс выполнения операторов SQL
Следует отметить, что перечисленные этапы отличаются по числу обращений к БД и по процессорному времени, требуемому для их выполнения. Синтаксический анализ проводится очень быстро, он не требует обращения к системным каталогам БД. Семантический анализ уже требует работы с базой мета-данных, то есть с системными каталогами БД, поэтому при выполнении этого этапа происходит обращение к системному каталогу и серьезная работа с ним. Этап, связанный с оптимизаций плана запроса, требует работы не только с системным каталогом, но и со статистической информацией о БД, которая характеризует текущее состояние всех отношений, используемых в запросе, их физическое расположение на страницах и сегментах внешней памяти. В силу указанных причин этап оптимизации наиболее трудоемкий и длительный в процессе выполнения запроса. Однако если не проводить этап оптимизации, то стоимость (время) выполнения неоптимизированного запроса может в несколько раз превысить стоимость оптимизированного запроса. Время, потраченное на оптимизацию запроса, с лихвой компенсирует затраты на выполнение неоптимизированного запроса.
Этапы выполнения операторов SQL одни и те же как в интерактивном режиме, так и внутри приложений.
Однако при работе с готовым приложением многие этапы СУБД может выполнить заранее.
1. Электромагнитная волна (в религиозной терминологии релятивизма - "свет") имеет строго постоянную скорость 300 тыс.км/с, абсурдно не отсчитываемую ни от чего. Реально ЭМ-волны имеют разную скорость в веществе (например, ~200 тыс км/с в стекле и ~3 млн. км/с в поверхностных слоях металлов, разную скорость в эфире (см. статью "Температура эфира и красные смещения"), разную скорость для разных частот (см. статью "О скорости ЭМ-волн")
2. В релятивизме "свет" есть мифическое явление само по себе, а не физическая волна, являющаяся волнением определенной физической среды. Релятивистский "свет" - это волнение ничего в ничем. У него нет среды-носителя колебаний.
3. В релятивизме возможны манипуляции со временем (замедление), поэтому там нарушаются основополагающие для любой науки принцип причинности и принцип строгой логичности. В релятивизме при скорости света время останавливается (поэтому в нем абсурдно говорить о частоте фотона). В релятивизме возможны такие насилия над разумом, как утверждение о взаимном превышении возраста близнецов, движущихся с субсветовой скоростью, и прочие издевательства над логикой, присущие любой религии.
4. В гравитационном релятивизме (ОТО) вопреки наблюдаемым фактам утверждается об угловом отклонении ЭМ-волн в пустом пространстве под действием гравитации. Однако астрономам известно, что свет от затменных двойных звезд не подвержен такому отклонению, а те "подтверждающие теорию Эйнштейна факты", которые якобы наблюдались А. Эддингтоном в 1919 году в отношении Солнца, являются фальсификацией. Подробнее читайте в FAQ по эфирной физике.
|
![]() |