Перейти к оглавлению
       3. ИСПОЛЬЗОВАНИЕ SQL ДЛЯ ИЗВЛЕЧЕНИЯ ИНФОРМАЦИИ ИЗ ТАБЛИЦ.
 
 
 
 
   В ЭТОЙ  ГЛАВЕ МЫ ПОКАЖЕМ ВАМ КАК ИЗВЛЕКАТЬ информацию из таблиц.  Вы
 узнаете как опускать или переупорядочивать столбцы и как автоматически
 устранять избыточность данных из вашего вывода. В заключение, вы узна-
 ете как устанавливать условие( проверку ) которую вы можете  использо-
 вать чтобы определить какие строки таблицы используются в выводе.  Эта
 последняя особенность,  будет далее описана в более поздних  главах  и
 является одной из наиболее изящных и мощных в SQL.
 
 
               =========   СОЗДАНИЕ ЗАПРОСА   ===========
 
 
   Как мы подчеркивали ранее, SQL символизирует собой Структурированный
 Язык Запросов.  Запросы - вероятно наиболее часто используемый  аспект
 SQL.  Фактически,  для категории SQL пользователей, маловероятно чтобы
 кто-либо использовал этот язык для чего-то друго.  По этой причине, мы
 будем  начинать  наше обсуждение SQL с обсуждения запроса и как он вы-
 полняется на этом языке.
 
 
                           ЧТО ТАКОЕ ЗАПРОС ?
 
 
   Запрос - команда которую вы даете вашей программе базы данных, и ко-
 торая сообщает ей чтобы она вывела определенную информацию из таблиц в
 память.  Эта информация обычно  посылается  непосредственно  на  экран
 компьютера или терминала которым вы пользуетесь,  хотя,  в большинстве
 случаев, ее можно также послать принтеру, сохранить в файле ( как объ-
 ект в памяти компьютера ),  или представить как вводную информацию для
 другой команды или процесса.
 
 
                       ГДЕ ПРИМЕНЯЮТСЯ ЗАПРОСЫ ?
 
 
   Запросы обычно рассматриваются как часть языка DML.  Однако, так как
 запрос не меняет информацию в таблицах, а просто показывает ее пользо-
 вателю,  мы будем рассматривать запросы как самостоятельную  категорию
 среди  команд DML которые производят действие,  а не просто показывают
 содержание базы данных.
   Все запросы в SQL состоят из одиночной команды.  Структура этой  ко-
 манды  обманчиво  проста,  потому что вы должны расширять ее так чтобы
 выполнить высоко сложные оценки и обработки данных.  Эта команда назы-
 вается - SELECT(ВЫБОР).
 
 
                            КОМАНДА  SELECT
 
 
   В самой простой форме, команда SELECT просто инструктирует базу дан-
 ных чтобы извлечь информацию из таблицы. Например, вы могли бы вывести
 таблицу Продавцов напечатав следующее:
 
 
         SELECT snum, sname, sity, comm
           FROM  Salespeople;
 
 
   Вывод для этого запроса показывается в Рисунке 3.1.
 
 
            ===============  SQL Execution Log ============
           |                                               |
           | SELECT snum, sname, sity, comm                |
           | FROM  Salespeople;                            |
           |                                               |
           | ==============================================|
           |   snum      sname         city         comm   |
           | ------    ----------   -----------   -------  |
           |   1001      Peel         London        0.12   |
           |   1002      Serres       San Jose      0.13   |
           |   1004      Motika       London        0.11   |
           |   1007      Rifkin       Barcelona     0.15   |
           |   1003      Axelrod      New York      0.10   |
            ===============================================
 
 
 Рисунок 3.1: команда SELECT
 
 
   Другими словами,  эта команда просто выводит все данные из  таблицы.
 Большинство программ будут также давать заголовки столбца как выше,  а
 некоторые позволяют детальное форматирование вывода,  но это  уже  вне
 стандартной спецификации.
   Имеется объяснение каждой части этой команды:
 
 
 SELECT         Ключевое слово  которое сообщает базе данных что эта
                команда - запрос. Все запросы начинаются этим словом,
                сопровождаемым пробелом.
 
 
 snum, sname    Это - список столбцов из таблицы которые выбираются
                запросом. Любые столбцы не перечисленные здесь не
                будут включены в вывод команды. Это, конечно, не значит
                что они будут удалены или их информация будет стерта
                из таблиц, потому что запрос не воздействует на
                информацию в таблицах; он только показывает данные.
 
 
 FROM          FROM - ключевое слово, подобно SELECT, которое должно
 Salespeople   быть представлено в каждом запросе. Оно сопровожда-
               ется пробелом и затем именем таблицы используемой
               в качестве источника информации.
               В данном случае - это таблица Продавцов(Salespeople).
 
 
     ;         Точка с запятой используется во всех интерактивных
               командах SQL чтобы сообщать базе данных что команда
               заполнена и готова выполниться.
               В некоторых системах наклонная черта влево (\) в строке,
               является индикатором конца команды.
 
 
   Естественно, запрос такого характера не обязательно будет упорядочи-
 вать вывод любым указаным способом.  Та же самая команда выполненная с
 теми  же самыми данными но в разное время не сможет вывести тот же са-
 мый порядок. Обычно, строки обнаруживаются в том порядке в котором они
 найдены  в  таблице,  поскольку как мы установили в предыдущей главе -
 этот порядок произволен.  Это не обязательно будет тот порядок в кото-
 ром  данные  вводились или сохранялись.  Вы можете упорядочивать вывод
 командами SQL непосредственно:  с  помощью  специального  предложения.
 Позже,  мы покажем как это делается.  А сейчас,  просто усвойте, что в
 отсутствии явного упорядочения,  нет никакого определенного порядка  в
 вашем выводе.
 
 
   Наше использование возврата ( Клавиша ENTER ) является произвольным.
 Мы должны точно установить как удобнее составить запрос,  в  несколько
 строк или в одну строку, следующим образом:
 
 
       SELECT snum, sname, city, comm FROM Salespeople;
 
 
   С тех  пор  как SQL использует точку с запятой чтобы указывать конец
 команды,  большинство программ SQL обрабатывают возврат  (через  нажим
 Возврат  или клавишу ENTER ) как пробел.  Это - хорошая идея чтобы ис-
 пользовать возвраты и выравнивание что мы делали это ранее, чтобы сде-
 лать ваши команды более легкими для чтения и более правильными.
 
 
                 ВЫБИРАЙТЕ ВСЕГДА САМЫЙ ПРОСТОЙ СПОСОБ
 
 
   Если вы хотите видеть каждый столбец таблицы, имеется необязательное
 сокращение которое вы можете использовать.  Звездочка (*) может приме-
 няться для вывода полного списка столбцов следующим образом:
 
 
       SELECT *
       FROM Salespeople;
 
 
   Это привыведет к тому же результату что и наша предыдущая команда.
 
 
                            ОПИСАНИЕ SELECT
 
 
   В общем случае,  команда SELECT начинается с ключевого слова SELECT,
 сопровождаемого  пробелом.  После  этого  должен следовать список имен
 столбцов которые вы хотите видеть, отделяемые запятыми. Если вы хотите
 видеть все столбцы таблицы,  вы можете заменить этот список звездочкой
 (*).  Ключевое слово FROM следующее далее,  сопровождается пробелом  и
 именем таблицы запрос к которой делается.  В заключение, точка с запя-
 той ( ;  ) должна использоваться чтобы закончить запрос и указать  что
 команда готова к выполнению.
 
 
             ПРОСМОТР ТОЛЬКО ОПРЕДЕЛЕННОГО СТОЛБЦА ТАБЛИЦЫ
 
 
   Команда SELECT  способна  извлечь  строго определенную информацию из
 таблицы. Сначала, мы можем предоставить возможность увидеть только оп-
 ределенные столбцы таблицы. Это выполняется легко, простым исключением
 столбцов которые вы не хотите видеть,  из части команды SELECT. Напри-
 мер, запрос
 
 
    SELECT sname, comm
       FROM Salespeople;
 
 
 будет производить вывод показанный на Рисунке 3.2.
 
 
          ===============  SQL Execution Log ============
         |                                               |
         | SELECT snum, comm                             |
         | FROM  Salespeople;                            |
         |                                               |
         | ==============================================|
         |        sname             comm                 |
         |   -------------      ---------                |
         |        Peel              0.12                 |
         |        Serres            0.13                 |
         |        Motika            0.11                 |
         |        Rifkin            0.15                 |
         |        Axelrod           0.10                 |
          ===============================================
 
 
 Рисунок 3.2: Выбор определенных столбцов
 
 
   Могут иметься  таблицы которые имеют большое количество столбцов со-
 держащих данные, не все из которых являются относящимися к поставленой
 задаче.  Следовательно, вы можете найти способ подбора и выбора только
 полезных для Вас столбцов.
 
 
                        ПЕРЕУПОРЯДОЧЕНИЕ СТОЛБЦА
 
 
   Даже если столбцы таблицы,  по определению, упорядоченны, это не оз-
 начает  что  вы  будете восстанавливать их в том же порядке.  Конечно,
 звездочка (*) покажет все столбцы в их естественном порядке,  но  если
 вы укажете столбцы отдельно, вы можете получить их в том порядке кото-
 ром хотите.  Давайте рассмотрим таблицу Порядков, содержащую дату при-
 обретения(odate),  номер продавца(snum),  номер порядка(onum), и суммы
 приобретения(amt):
 
 
    SELECT odate, snum, onum, amt
       FROM Orders;
 
 
   Вывод этого запроса показан на Рисунке 3.3.
 
 
      =============  SQL Execution Log  ===============
     |                                                 |
     |  SELECT odate, snum, onum, amt                  |
     |  FROM Orders;                                   |
     |                                                 |
     | ------------------------------------------------|
     |     odate        snum        onum          amt  |
     | -----------   -------      ------     --------- |
     | 10/03/1990       1007        3001         18.69 |
     | 10/03/1990       1001        3003        767.19 |
     | 10/03/1990       1004        3002       1900.10 |
     | 10/03/1990       1002        3005       5160.45 |
     | 10/03/1990       1007        3006       1098.16 |
     | 10/04/1990       1003        3009       1713.23 |
     | 10/04/1990       1002        3007         75.75 |
     | 10/05/1990       1001        3008       4723.00 |
     | 10/06/1990       1002        3010       1309.95 |
     | 10/06/1990       1001        3011       9891.88 |
     |                                                 |
       ===============================================
 
 
 Рисунок 3.3: Реконструкция столбцов
 
 
   Как вы можете видеть,  структура информации в таблицах - это  просто
 основа для активной перестройки структуры в SQL.
 
 
                       УДАЛЕНИЕ ИЗБЫТОЧНЫХ ДАННЫХ
 
 
   DISTINCT (ОТЛИЧИЕ) - аргумент который обеспечивает Вас способом уст-
 ранять двойные значения из вашего предложения SELECT.  Предположим что
 вы  хотите знать какие продавцы в настоящее время имеют свои порядки в
 таблице Порядков. Под порядком (здесь и далее) будет пониматься запись
 в таблицу Порядков, регистрирующую приобретения сделанные в определен-
 ный день определенным заказчиком у определенного продавца  на  опреде-
 ленную сумму).  Вам не нужно знать, сколько порядков имеет каждый; вам
 нужен только список номеров продавцов (snum).  Поэтому Вы можете ввес-
 ти:
 
 
      SELECT snum
        FROM Orders;
 
 
 для получения вывода показанного в Рисунке 3.4
 
 
                ===============  SQL Execution Log ============
               |                                               |
               | SELECT snum                                   |
               | FROM  Orders;                                 |
               |                                               |
               | ============================================= |
               |   snum                                        |
               | -------                                       |
               |   1007                                        |
               |   1001                                        |
               |   1004                                        |
               |   1002                                        |
               |   1007                                        |
               |   1003                                        |
               |   1002                                        |
               |   1001                                        |
               |   1002                                        |
               |   1001                                        |
                 =============================================
 
 
 Рисунок 3. 4: SELECT с дублированием номеров продавцов.
 
 
   Для получения списка без дубликатов,  для удобочитаемости, вы можете
 ввести следующее:
 
 
        SELECT DISTINCT snum
           FROM Orders;
 
 
   Вывод для этого запроса показан в Рисунке 3.5.
 
 
   Другими словами,  DISTINCT следит за тем, какие значения были ранее,
 так что бы они не были продублированы в списке.  Это - полезный способ
 избежать избыточности данных, но важно что бы при этом вы понимали что
 вы делаете.  Если вы не хотите потерять некоторые данные, вы не должны
 безоглядно использовать DISTINCT, потому что это может скрыть какую-то
 проблему или какие-то важные данные.  Например,  вы могли бы предполо-
 жить что имена всех ваших заказчиков различны.  Если  кто-то  помещает
 второго Clemens в таблицу Заказчиков, а вы используете SELECT DISTINCT
 cname, вы не будете даже знать о существовании двойника. Вы можете по-
 лучить не того Clemens и даже не знать об этом. Так как вы не ожидаете
 избыточности, в этом случае вы не должны использовать DISTINCT.
 
 
                           ПАРАМЕТРЫ DISTINCT
 
 
   DISTINCT может указываться только один раз в данном предложении  SE-
 LECT. Если предложение выбирает многочисленные поля,
 
 
                ===============  SQL Execution Log ============
               |                                               |
               | SELECT DISTINCT snum                          |
               | FROM  Orders;                                 |
               |                                               |
               | ============================================= |
               |   snum                                        |
               | -------                                       |
               |   1001                                        |
               |   1002                                        |
               |   1003                                        |
               |   1004                                        |
               |   1007                                        |
                 =============================================
 
 
 Рисунок 3.5: SELECT без дублирования
 
 
   DISTINCT опускает строки где все выбранные поля идентичны.  Строки в
 которых некоторые значения одинаковы а некоторые различны - будут сох-
 ранены. DISTINCT, фактически, приводит к показу всей строки вывода, не
 указывая  полей ( за исключением когда он используется внутри агрегат-
 ных функций, как описано в Главе 6 ), так что нет никакого смысла что-
 бы его повторять.
 
 
                          DISTINCT ВМЕСТО ALL
 
 
   Вместо DISTINCT, вы можете указать - ALL. Это будет иметь противопо-
 ложный эффект, дублирование строк вывода сохранится. Так как это - тот
 же самый случай когда вы не указываете ни DISTINCT ни ALL, то ALL - по
 существу скорее пояснительный, а не действующий аргумент.
 
 
                      КВАЛИФИЦИРОВАННЫЙ ВЫБОР  ПРИ
               ======= ИСПОЛЬЗОВАНИИ ПРЕДЛОЖЕНИЙ ========
 
 
   Таблицы имеют тенденцию становиться очень большими,  поскольку с те-
 чением времени,  все большее и большее количество строк в нее добавля-
 ется.  Поскольку  обычно  из них только определенные строки интересуют
 вас в данное время,  SQL дает возможность вам  устанавливать  критерии
 чтобы определить какие строки будут выбраны для вывода.
 
 
   WHERE - предложение команды SELECT, которое позволяет вам устанавли-
 вать предикаты, условие которых может быть или верным или неверным для
 любой  строки  таблицы.  Команда извлекает только те строки из таблицы
 для которой такое утверждение верно.  Например,  предположим вы хотите
 видеть имена и комиссионные всех продавцов в Лондоне. Вы можете ввести
 такую команду:
 
 
       SELECT sname, city
         FROM Salespeople;
         WHERE city = "LONDON";
 
 
   Когда предложение WHERE представлено, программа базы данных просмат-
 ривает всю таблицу по одной строке и исследует каждую строку чтобы оп-
 ределить верно ли утверждение.  Следовательно,  для записи Peel, прог-
 рамма рассмотрит текущее значение столбца city, определит что оно рав-
 но "London",  и включит эту строку в вывод. Запись для Serres не будет
 включена, и так далее. Вывод для вышеупомянутого запроса показан в Ри-
 сунке 3.6.
                ===============  SQL Execution Log ============
               |                                               |
               | SELECT sname, city                            |
               | FROM  Salespeople                             |
               | WHERE city = 'London'                         |
               | ============================================= |
               |   sname           city                        |
               |  -------       ----------                     |
               |   Peel            London                      |
               |   Motika          London                      |
                 =============================================
 
 
 Рисунок 3.6: SELECT c предложением WHERE
 
 
   Давайте попробуем пример с числовым полем в предложении WHERE.  Поле
 rating таблицы Заказчиков предназначено чтобы разделять заказчиков  на
 группы основанные на некоторых критериях которые могут быть получены в
 итоге через этот номер. Возможно это - форма оценки кредита или оценки
 основанной на томе предыдущих приобретений.  Такие числовые коды могут
 быть полезны в реляционных базах данных как способ  подведения  итогов
 сложной информации.  Мы можем выбрать всех заказчиков с рейтингом 100,
 следующим образом:
 
 
      SELECT *
         FROM Customers
         WHERE rating = 100;
 
 
   Одиночные кавычки не используются здесь потому,  что  оценка  -  это
 числовое поле. Результаты запроса показаны в Рисунке 3. 7.
 
 
   Предложение WHERE  совместимо  с предыдущим материалом в этой главе.
 Другими словами,  вы можете использовать  номера  столбцов,  устранять
 дубликаты,  или переупорядочивать столбцы в команде SELECT которая ис-
 пользует WHERE.  Однако,  вы можете изменять порядок столбцов для имен
 только в предложении SELECT, но не в предложении WHERE.
 
 
                ===============  SQL Execution Log ============
               |                                               |
               | SELECT *                                      |
               | FROM  Customers                               |
               | WHERE rating = 100;                           |
               | ============================================= |
               |   сnum     cname    city     rating    snum   |
               |  ------   --------  ------    ----   ------   |
               |   2001     Hoffman  London     100     1001   |
               |   2006     Clemens  London     100     1001   |
               |   2007     Pereira  Rome       100     1001   |
                 =============================================
 
 
 Рисунок 3.7:  SELECT с числовым полем в предикате
 
 
               ===============   РЕЗЮМЕ   ===============
 
 
   Теперь вы знаете несколько способов заставить таблицу давать вам  ту
 информацию какую вы хотите,  а не просто выбрасывать наружу все ее со-
 держание.  Вы можете переупорядочивать столбцы таблицы  или  устранять
 любую из них.  Вы можете решать, хотите вы видеть дублированные значе-
 ния или нет.
   Наиболее важно  то,  что  вы можете устанавливать условие называемое
 предикатом которое определяет или не определяет указанную строку  таб-
 лицы из тысяч таких же строк, будет ли она выбрана для вывода.
   Предикаты могут становиться очень сложными, предоставляя вам высокую
 точность в решении, какие строки вам выбирать с помощью запроса. Имен-
 но эта способность решать точно,  что вы хотите видеть, делает запросы
 SQL такими мощными.  Следующие несколько глав будут посвещены, в боль-
 шей мере,  особенностям которые расширяют мощность предикатов. В Главе
 4, вам будут представлены операторы иные чем те которые используются в
 условиях предиката,  а также способы объединения многочисленых условий
 в единый предикат.
 
 
               ************* РАБОТА С SQL ***************
 
 
   1. Напишите команду SELECT которая бы вывела номер порядка, сумму, и
      дату для всех строк из таблицы Порядков.
   2. Напишите запрос который вывел бы все строки из таблицы Заказчиков
      для которых номер продавца = 1001.
   3. Напишите запрос который вывел бы таблицу со столбцами в следующем
      порядке: city, sname, snum, comm.
   4. Напишите команду SELECT которая вывела бы оценку(rating),  сопро-
      вождаемую именем каждого заказчика в San Jose.
   5. Напишите  запрос  который вывел бы значения snum всех продавцов в
      текущем порядке из таблицы Порядков без каких бы то ни было  пов-
      торений.
 
 
 ( См. Приложение A для ответов. )
 
 
 
Перейти к оглавлению
Hosted by uCoz