2019-02-21 21:18:12 +03:00
---
language: SQL
2019-08-21 09:47:17 +03:00
filename: learnsql-ru.sql
2019-02-21 21:18:12 +03:00
contributors:
- ["Bob DuCharme", "http://bobdc.com/"]
translators:
- ["Shaltaev", "https://github.com/shaltaev"]
2019-10-05 19:09:59 +03:00
- ["Andre Polykanine", "https://github.com/Menelion"]
2019-02-21 21:18:12 +03:00
lang: ru-ru
---
2019-10-05 19:09:59 +03:00
Язык структурированных запросов (SQL) — это стандартный язык ISO для создания
и работы с базами данных, хранящимися в наборе таблиц. Реализации обычно
добавляют свои собственные расширения к языку;
[Сравнение различных реализаций SQL ](http://troels.arvin.dk/db/rdbms/ ) — хороший справочник по различиям в продуктах.
Реализации обычно предоставляют приглашение командной строки, где вы можете
вводить команды, описанные ниже, в интерактивном режиме, также есть способ
выполнить серию таких команд, сохранённых в файле скрипта.
(Результат того, что вы сделали с помощью интерактивного режима, является
хорошим примером того, что не стандартизировано, — большинство реализаций SQL
поддерживают ключевые слова QUIT, EXIT или о б а ).
Некоторые команды ниже предполагают использование
[демонстрационного образца базы данных сотрудников от MySQL ](https://dev.mysql.com/doc/employee/en/ ), доступного на [Github ](https://github.com/datacharmer/test_db ).
Следовательно, для повторения команд в локальном окружении он должен быть загружен.
Файлы на github — это скрипты с командами, которые схожи с командами ниже,
которые создают и манипулируют таблицами и данными о сотрудниках вымышленной
компании. Синтаксис для запуска этих скриптов будет зависеть от используемой
вами реализации SQL. Обычно используется утилита, запускаемая из командной
строки в вашей операционной системе.
2019-02-21 21:18:12 +03:00
```sql
2019-10-05 19:09:59 +03:00
-- Комментарии начинаются с двух дефисов. Завершайте каждую команду
2019-02-21 21:18:12 +03:00
-- точкой с запятой.
2019-10-05 19:09:59 +03:00
-- SQL не учитывает регистр букв для ключевых слов. Примеры команд здесь
-- следуют соглашению о написании в верхнем регистре, потому что
-- это позволяет легче отличить их от имён баз, таблиц и колонок.
2019-02-21 21:18:12 +03:00
-- Создание и удаление базы данных. Имена базы и таблицы чувствительны
2019-10-05 19:09:59 +03:00
-- к регистру букв.
2019-02-21 21:18:12 +03:00
CREATE DATABASE someDatabase;
DROP DATABASE someDatabase;
-- Список доступных баз.
SHOW DATABASES;
-- Выбор базы для работы.
USE employees;
2019-10-05 19:09:59 +03:00
-- Выбрать все строки и колонки из таблицы «departments» (отделы) текущей базы.
-- В интерактивном режиме обыч но результат будет выведен на экран.
2019-02-21 21:18:12 +03:00
SELECT * FROM departments;
2019-10-05 19:09:59 +03:00
-- Тот же запрос, что и выше, но выбор только колонок «dept_no» и «dept_name».
2019-02-21 21:18:12 +03:00
-- Разбиение команд на несколько строк допустимо.
SELECT dept_no,
dept_name FROM departments;
2019-10-05 19:09:59 +03:00
-- В данном случае будут выбраны все колонки, но только первые 5 строк.
2019-02-21 21:18:12 +03:00
SELECT * FROM departments LIMIT 5;
2019-10-05 19:09:59 +03:00
-- Выбор названий отделов, содержащих подстроку «en».
2019-02-21 21:18:12 +03:00
SELECT dept_name FROM departments WHERE dept_name LIKE '%en%';
2019-10-05 19:09:59 +03:00
-- Выбор всех колонок, где названия отделов начинаются на «S»,
-- после которой идёт ровно четыре символа.
2019-02-21 21:18:12 +03:00
SELECT * FROM departments WHERE dept_name LIKE 'S____';
2019-10-05 19:09:59 +03:00
-- Выбор всех должностей из таблицы «titles», но без повторений.
2019-02-21 21:18:12 +03:00
SELECT DISTINCT title FROM titles;
-- В дополнение к предыдущему запросу результат будет отсортирован
2019-10-05 19:09:59 +03:00
-- в алфавитном порядке (с учётом регистра).
2019-02-21 21:18:12 +03:00
SELECT DISTINCT title FROM titles ORDER BY title;
2019-10-05 19:09:59 +03:00
-- Показать число строк в таблице отделов.
2019-02-21 21:18:12 +03:00
SELECT COUNT(*) FROM departments;
2019-10-05 19:09:59 +03:00
-- Показать число строк, где название отдела содержит подстроку «en»
2019-02-21 21:18:12 +03:00
SELECT COUNT(*) FROM departments WHERE dept_name LIKE '%en%';
2019-10-05 19:09:59 +03:00
-- Объединение информации из нескольких таблиц:
-- В таблице «titles» перечислены должности, кто их занимал по номеру сотрудника,
-- а также с какой даты по какую. Получим эту информацию, но используем номера
-- сотрудников как ссылку на таблицу «employees», чтобы получить имя и фамилию
-- каждого сотрудника. Выводим только 10 строк.
2019-02-21 21:18:12 +03:00
SELECT employees.first_name, employees.last_name,
titles.title, titles.from_date, titles.to_date
FROM titles INNER JOIN employees ON
employees.emp_no = titles.emp_no LIMIT 10;
-- Список всех таблиц во всех базах. Реализации обычно предоставляют
2019-10-05 19:09:59 +03:00
-- собственные сокращения, чтобы показать все таблицы текущей базы.
2019-02-21 21:18:12 +03:00
SELECT * FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_TYPE='BASE TABLE';
2019-10-05 19:09:59 +03:00
-- Создать таблицу с именем tablename1 и двумя колонками в текущей базе.
-- Для колонок имеется множество параметров, таких как тип данных.
2019-02-21 21:18:12 +03:00
CREATE TABLE tablename1 (fname VARCHAR(20), lname VARCHAR(20));
2019-10-05 19:09:59 +03:00
-- Вставляем строку данных в таблицу «tablename1». Предполагаем, что таблица
-- настроена таким образом, чтобы принимать эти значения.
2019-02-21 21:18:12 +03:00
INSERT INTO tablename1 VALUES('Richard','Mutt');
2019-10-05 19:09:59 +03:00
-- В таблице «tablename1» изменить значение fname на «John»
-- для каждой строки, где колонка lname равна «Mutt».
2019-02-21 21:18:12 +03:00
UPDATE tablename1 SET fname='John' WHERE lname='Mutt';
2019-10-05 19:09:59 +03:00
-- Удалить из таблицы «tablename1» строки,
-- где значение колонки lname начинается с «M».
2019-02-21 21:18:12 +03:00
DELETE FROM tablename1 WHERE lname like 'M%';
2019-10-05 19:09:59 +03:00
-- Удалить все строки из таблицы «tablename1». В итоге получим пустую таблицу.
2019-02-21 21:18:12 +03:00
DELETE FROM tablename1;
2019-10-05 19:09:59 +03:00
-- Удалить таблицу «tablename1» полностью.
2019-02-21 21:18:12 +03:00
DROP TABLE tablename1;
```