Компьютеры
и программирование

SQL SELECT - запрос на выборку данных

Оператор языка SQL SELECT предназначен для запросов на выборку данных из базы данных. Он может быть использован как без условий (выбор всех столбцов), так и с многочисленными условиями.

SELECT для выбора столбцов таблицы

Запрос с оператором SELECT для выбора всех столбцов таблицы имеет следующий синтаксис:

SELECT * FROM ИМЯ_ТАБЛИЦЫ

То есть для выбора всех столбцов таблицы после слова SELECT нужно ставить звёздочку.

Пример 1. Есть база данных фирмы - Company. В ней есть таблица Org (Структура фирмы) и Staff (Сотрудники). Требуется выбрать из таблиц все столбцы. Соответствующий запрос для выбора всех столбцов из таблицы Org выглядит следующим образом:

SELECT * FROM ORG

Этот запрос вернёт следующее (для увеличения картинки щёлкнуть по ней левой кнопкой мыши):

Запрос для выбора всех столбцов из таблицы Staff выглядит следующим образом:

SELECT * FROM STAFF

Этот запрос вернёт следующее:

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

Пример 2. Пусть требуется из таблицы Org Depnumb Deptname, в которых содержатся данные соответственно о номерах отделов фирмы и об их названиях. Запрос для получения такой выборки будет следующим:

SELECT DEPNUMB, DEPTNAME FROM ORG

А из таблицы Staff нужно выбрать столбцы DEPT, NAME, JOB, в которых содержатся соответственно данные о номере отдела, в котором трудится сотрудник, его имени и должности:

SELECT DEPT, NAME, JOB FROM STAFF

SELECT для выбора строк таблицы

Для выбора определённых строк таблицы уже потребуется ключевое слово WHERE, указывающее на некоторое значение или несколько значений, содержащиеся в интересующих нас строках.

Пример 3. Выберем из таблицы Staff строки, в которых содержатся данные только о сотрудниках, которые работают в 38-м отделе:

SELECT DEPT, NAME, JOB FROM STAFF WHERE DEPT=38

Этот запрос вернёт следующие данные:

Пример 4. В предыдущем примере мы выбирали строки из таблицы только по значению одного столбца - DEPT. Пусть теперь нужно выбрать данные о сотрудниках, которые работают в 38-м отделе и должность которых - служащий (Clerk). Для этого соответствующие значения нужно перечислить с использованием слова AND:

SELECT DEPT, NAME, JOB FROM STAFF WHERE JOB='Clerk' AND DEPT=38

Этот запрос вернёт следующие данные:

Пример 5. Пусть нужно выбрать из таблицы Staff идентификаторы и имена тех сотрудников, размер комиссии которых - неопределённый. Для этого перед указанием значения столбца COMM - NULL нужно ставить не знак равенства, а слово IS:

SELECT ID, NAME FROM STAFF WHERE COMM IS NULL

Этот запрос вернёт следующие данные:

Для указания значений в строках, которые требуется выбрать, используются и знаки сравнения.

Пример 6. Выберем из таблицы имена, размеры заработные платы и число лет, проработанных в фирме, сотрудников, которые работают в фирме более девяти лет:

SELECT NAME, SALARY, YEARS FROM STAFF WHERE YEARS>9

Запрос вернёт следующие строки:

Использование SELECT и предикатов

Предикаты - слова IN, OR, BETWEEN, LIKE - также позволяют выбрать определённые диапазоны значений (первые три) или значения в строках, которые требуется выбрать из таблицы.

Пример 7. Пусть требуется выбрать из таблицы Staff имена, должности и число отработанных лет сотрудников, работающих в отделах с номерами 20 или 84. Это можно сделать следующим запросом:

SELECT NAME, JOB, YEARS FROM STAFF WHERE DEPT IN (20, 84)

Результат выполнения запроса:

Пример 8. Пусть теперь требуется выбрать из таблицы Staff те же данные, что и в предыдущем примере. Запрос со словом OR аналогичен запросу со словом IN и перечислением интересующих значений в скобках. Запрос будет следующим:

SELECT NAME, JOB, YEARS FROM STAFF WHERE DEPT=20 OR DEPT=84

Пример 9. Выберем из той же таблицы имена, должности и число отработанных лет сотрудников, зарплата которых между 15000 и 17000 включительно:

SELECT NAME, JOB, YEARS FROM STAFF WHERE SALARY BETWEEN 15000 AND 17000

Результат выполнения запроса:

Предикат LIKE используется для выборки тех строк, в значениях которых встречаются символы, указанные после предиката между апострофами (').

Пример 10. Выберем из той же таблицы имена, должности и число отработанных лет сотрудников, имена которых начинаются с буквы S и состоят из 7 символов:

SELECT NAME, JOB, YEARS FROM STAFF WHERE NAME LIKE 'S_ _ _ _ _ _'

Символ подчёркивания (_) означает любой символ. Результат выполнения запроса:

Пример 11. Выберем из той же таблицы имена, должности и число отработанных лет сотрудников, имена которых начинаются с буквы S и содержат любые другие буквы в любом количестве:

SELECT NAME, JOB, YEARS FROM STAFF WHERE NAME LIKE 'S%'

Символ процентов (%) означает любое количество символов. Результат выполнения запроса:

Значения, указанные с использованием предикатов IN, OR, BETWEEN, LIKE можно инвертировать при помощи слова NOT. Тогда запрашиваемые данные будут иметь противоположный смысл. Если мы используем NOT IN (20, 84), то будут выведены данные сотрудников, которые работают во всех отделах, кроме имеющих номера 20 и 84. С использованием NOT BETWEEN 15000 AND 17000 можно получить данные сотрудников, зарплата которых не входит в интервал от 15000 до 17000. Запрос с NOT LIKE выведет данные сотрудников, чьи имена не начинаются или не содержат символов, указанных с NOT LIKE.

SELECT и сортировка (упорядочение) строк

Разобранные до сих пор запросы возвращали строки, которые могли быть расположены в любой последовательности. Однако часто требуется отсортировать строки по порядку номеров, алфавиту и другим признакам. Для этого служит ключевое словосочетание ORDER BY.

Пример 12. Пусть требуетя выбрать из таблицы Staff сотрудников, работающих в отделе с номером 84 и отсортировать (упорядочить) записи по числу отработанных лет в возрастающем порядке:

SELECT NAME, JOB, YEARS FROM STAFF WHERE DEPT=84 ORDER BY YEARS ASC

Слово ASC указывает, что порядок сортировки - возрастающий. Это слово не обязательно, так как возрастающий порядок сортировки применяется по умолчанию. Результат выполнения запроса:

Пример 13. Пусть требуетя выбрать те же данные, что и в предыдущем примере, но отсортировать (упорядочить) записи по числу отработанных лет в убывающем порядке:

SELECT NAME, JOB, YEARS FROM STAFF WHERE DEPT=84 ORDER BY YEARS DESC

Слово DESC указывает, что порядок сортировки - убывающий. Результат выполнения запроса:

SELECT и удаление дубликатов строк

Когда для значений строк таблицы не задано условие уникальности, в результатах запроса могут встретиться одинаковые строки. Часто требуется вывести лишь уникальные строки. Это делается при помощи выражения DISTINCT.

Пример 14. Пусть требуетcя узнать, какие существуют отделы и какие должности среди отделов, номера которых меньше 30. Это можно сделать при помощи следующего запроса:

SELECT DISTINCT DEPT, JOB FROM STAFF WHERE DEPT<30 ORDER BY DEPT, JOB

Результат выполнения запроса:

Поделиться с друзьями

Другие темы в блоке "Реляционные базы данных"