22
SELECT GROUP BY INSERT, UPDATE, DELETE Язык SQL Информатика 10-11 классы 21 ноября 2012 г. Информатика 10-11 классы Язык SQL

SQL

Embed Size (px)

Citation preview

Page 1: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

Язык SQL

Информатика10-11 классы

21 ноября 2012 г.

Информатика 10-11 классы Язык SQL

Page 2: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

Повторим SELECT

Информатика 10-11 классы Язык SQL

Page 3: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

Оператор SELECT

id first_name last_name gender created_atВспомним один из простейших запросов:

Listing 1: SELECT

SELECT ∗ FROM u s e r sWHERE ( gender = 1)ORDER BY c rea ted_at DESCLIMIT 1

Информатика 10-11 классы Язык SQL

Page 4: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

Функции

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

Пример “раз”: есть таблица учеников students. Сколькоучеников имеет оценку 5?Пример “два”: какой максимальный балл набрал ученик затест?Пример “три”: чему равен средний балл по контрольной?Пример “четыре”: сколько пользователей банка запоследний месяц воспользовались услугамиИнтернет–банкинга?Для работы со всем этим и применяются специальныефункции.

Информатика 10-11 классы Язык SQL

Page 5: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

Функции

Зачастую встаёт задача не просто по выборке каких-либоданных из таблицы, а по их подсчёту.Пример “раз”: есть таблица учеников students. Сколькоучеников имеет оценку 5?

Пример “два”: какой максимальный балл набрал ученик затест?Пример “три”: чему равен средний балл по контрольной?Пример “четыре”: сколько пользователей банка запоследний месяц воспользовались услугамиИнтернет–банкинга?Для работы со всем этим и применяются специальныефункции.

Информатика 10-11 классы Язык SQL

Page 6: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

Функции

Зачастую встаёт задача не просто по выборке каких-либоданных из таблицы, а по их подсчёту.Пример “раз”: есть таблица учеников students. Сколькоучеников имеет оценку 5?Пример “два”: какой максимальный балл набрал ученик затест?

Пример “три”: чему равен средний балл по контрольной?Пример “четыре”: сколько пользователей банка запоследний месяц воспользовались услугамиИнтернет–банкинга?Для работы со всем этим и применяются специальныефункции.

Информатика 10-11 классы Язык SQL

Page 7: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

Функции

Зачастую встаёт задача не просто по выборке каких-либоданных из таблицы, а по их подсчёту.Пример “раз”: есть таблица учеников students. Сколькоучеников имеет оценку 5?Пример “два”: какой максимальный балл набрал ученик затест?Пример “три”: чему равен средний балл по контрольной?

Пример “четыре”: сколько пользователей банка запоследний месяц воспользовались услугамиИнтернет–банкинга?Для работы со всем этим и применяются специальныефункции.

Информатика 10-11 классы Язык SQL

Page 8: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

Функции

Зачастую встаёт задача не просто по выборке каких-либоданных из таблицы, а по их подсчёту.Пример “раз”: есть таблица учеников students. Сколькоучеников имеет оценку 5?Пример “два”: какой максимальный балл набрал ученик затест?Пример “три”: чему равен средний балл по контрольной?Пример “четыре”: сколько пользователей банка запоследний месяц воспользовались услугамиИнтернет–банкинга?

Для работы со всем этим и применяются специальныефункции.

Информатика 10-11 классы Язык SQL

Page 9: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

Функции

Зачастую встаёт задача не просто по выборке каких-либоданных из таблицы, а по их подсчёту.Пример “раз”: есть таблица учеников students. Сколькоучеников имеет оценку 5?Пример “два”: какой максимальный балл набрал ученик затест?Пример “три”: чему равен средний балл по контрольной?Пример “четыре”: сколько пользователей банка запоследний месяц воспользовались услугамиИнтернет–банкинга?Для работы со всем этим и применяются специальныефункции.

Информатика 10-11 классы Язык SQL

Page 10: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

Функции

Функция Аргументы ОписаниеCOUNT(*) не важно считает количество записей в вы-

боркеMAX(mark) название

столбцанаходит максимальное значение встолбце среди выбранных записей

MIN(mark) названиестолбца

находит минимальное значение встолбце среди выбранных записей

SUM(mark) названиестолбца

находит сумму значений из столбцаmark среди выбранных записей

AVG(mark) названиестолбца

находит среднее арифметическоезначение в столбце среди выбран-ных записей

Информатика 10-11 классы Язык SQL

Page 11: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

COUNT

id first_name last_name gender created_at

Таблица: users

Сколько записей в таблице users?

Listing 2: SELECT COUNT

SELECT COUNT(∗ ) FROM u s e r s ;

Результат: 6

Информатика 10-11 классы Язык SQL

Page 12: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

COUNT с условием

id first_name last_name gender created_at

Таблица: users

А сколько мужчин?

Listing 3: SELECT COUNT

SELECT COUNT(∗ ) FROM u s e r s WHERE gender =1;

Результат: 4

Информатика 10-11 классы Язык SQL

Page 13: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

MAX

id student_id gender mark created_at

Таблица: exam_results

Какое максимальное (минимальное) количество балловбыло набрано на экзамене?

Listing 4: SELECT MAX

SELECT MAX(mark ) FROM exam_resu l t s ;SELECT MIN(mark ) FROM exam_resu l t s ;

Информатика 10-11 классы Язык SQL

Page 14: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

AVG

id student_id gender mark created_at

Таблица: exam_results

А каков средний балл?

Listing 5: SELECT AVG

SELECT AVG(mark ) FROM exam_resu l t s ;

Информатика 10-11 классы Язык SQL

Page 15: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

GROUP BY

А что, если я хочу узнать, сколько учеников получилооценку 5, сколько 4, и т.п.?Конечно, можно выполнить ряд последовательныхзапросов с поиском через WHERE.Но есть альтернатива! — GROUP BY.Оператор GROUP BY группирует результаты по заданномуполю.

Информатика 10-11 классы Язык SQL

Page 16: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

GROUP BY и COUNT

id student_id gender mark created_at

Таблица: exam_results

Таблица: балл — количество учеников, его набравших.

Listing 6: GROUP BY

SELECT mark , COUNT(∗ ) FROM exam_resu l t sGROUP BY mark ;

Информатика 10-11 классы Язык SQL

Page 17: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

GROUP BY и AVG

id student_id gender mark created_at

Таблица: exam_results

А если ученики писали не один экзамен, а несколько? Какподсчитать средний балл по каждому ученику?

Listing 7: GROUP BY AVG

SELECT ∗ , AVG(mark ) FROM exam_resu l t sGROUP BY s tudent_id ;

Информатика 10-11 классы Язык SQL

Page 18: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

GROUP BY и HAVING

id student_id gender mark created_at

Таблица: exam_results

А если я хочу вывести только учеников, у которых среднийбалл выше 3? При этом отсортировать по убываниюбаллов?

Listing 8: GROUP BY HAVING

SELECT ∗ , AVG(mark ) AS avg_mark FROM exam_resu l t sGROUP BY s tudent_idHAVING avg_markORDER BY avg_mark DESC ;

Информатика 10-11 классы Язык SQL

Page 19: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

INSERT

id student_id gender mark created_at

Таблица: exam_results

Добавляем новую запись в таблицу.

Listing 9: INSERT

INSERT INTO exam_resu l t s ( s tudent_id , gender , mark )VALUES (1 , 1 , 5 ) ;

Информатика 10-11 классы Язык SQL

Page 20: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

UPDATE

id student_id gender mark created_at

Таблица: exam_results

Изменяем запись в таблицу.

Listing 10: UPDATE

UPDATE exam_resu l t s SET gender =2, mark=3WHERE i d = 5 ;

Информатика 10-11 классы Язык SQL

Page 21: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

DELETE

id student_id gender mark created_at

Таблица: exam_results

Удаляем.

Listing 11: DELETE

DELETE FROM exam_resu l t sWHERE c rea ted_at < "2012−01−01" ;

Информатика 10-11 классы Язык SQL

Page 22: SQL

SELECT GROUP BY INSERT, UPDATE, DELETE

Тестовая таблица courses

id title desc type is_active created_at updated_at1 Ruby ... 1 1 2012-01-01 2012-01-012 Info ... 0 0 2012-01-02 2012-02-013 Google ... 1 0 2012-03-25 2012-05-284 Test ... 0 1 2012-03-25 2012-11-13

Информатика 10-11 классы Язык SQL