Upload
evgeny-smirnov
View
822
Download
0
Embed Size (px)
Citation preview
SELECT GROUP BY INSERT, UPDATE, DELETE
Язык SQL
Информатика10-11 классы
21 ноября 2012 г.
Информатика 10-11 классы Язык SQL
SELECT GROUP BY INSERT, UPDATE, DELETE
Повторим SELECT
Информатика 10-11 классы Язык 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
SELECT GROUP BY INSERT, UPDATE, DELETE
Функции
Зачастую встаёт задача не просто по выборке каких-либоданных из таблицы, а по их подсчёту.
Пример “раз”: есть таблица учеников students. Сколькоучеников имеет оценку 5?Пример “два”: какой максимальный балл набрал ученик затест?Пример “три”: чему равен средний балл по контрольной?Пример “четыре”: сколько пользователей банка запоследний месяц воспользовались услугамиИнтернет–банкинга?Для работы со всем этим и применяются специальныефункции.
Информатика 10-11 классы Язык SQL
SELECT GROUP BY INSERT, UPDATE, DELETE
Функции
Зачастую встаёт задача не просто по выборке каких-либоданных из таблицы, а по их подсчёту.Пример “раз”: есть таблица учеников students. Сколькоучеников имеет оценку 5?
Пример “два”: какой максимальный балл набрал ученик затест?Пример “три”: чему равен средний балл по контрольной?Пример “четыре”: сколько пользователей банка запоследний месяц воспользовались услугамиИнтернет–банкинга?Для работы со всем этим и применяются специальныефункции.
Информатика 10-11 классы Язык SQL
SELECT GROUP BY INSERT, UPDATE, DELETE
Функции
Зачастую встаёт задача не просто по выборке каких-либоданных из таблицы, а по их подсчёту.Пример “раз”: есть таблица учеников students. Сколькоучеников имеет оценку 5?Пример “два”: какой максимальный балл набрал ученик затест?
Пример “три”: чему равен средний балл по контрольной?Пример “четыре”: сколько пользователей банка запоследний месяц воспользовались услугамиИнтернет–банкинга?Для работы со всем этим и применяются специальныефункции.
Информатика 10-11 классы Язык SQL
SELECT GROUP BY INSERT, UPDATE, DELETE
Функции
Зачастую встаёт задача не просто по выборке каких-либоданных из таблицы, а по их подсчёту.Пример “раз”: есть таблица учеников students. Сколькоучеников имеет оценку 5?Пример “два”: какой максимальный балл набрал ученик затест?Пример “три”: чему равен средний балл по контрольной?
Пример “четыре”: сколько пользователей банка запоследний месяц воспользовались услугамиИнтернет–банкинга?Для работы со всем этим и применяются специальныефункции.
Информатика 10-11 классы Язык SQL
SELECT GROUP BY INSERT, UPDATE, DELETE
Функции
Зачастую встаёт задача не просто по выборке каких-либоданных из таблицы, а по их подсчёту.Пример “раз”: есть таблица учеников students. Сколькоучеников имеет оценку 5?Пример “два”: какой максимальный балл набрал ученик затест?Пример “три”: чему равен средний балл по контрольной?Пример “четыре”: сколько пользователей банка запоследний месяц воспользовались услугамиИнтернет–банкинга?
Для работы со всем этим и применяются специальныефункции.
Информатика 10-11 классы Язык SQL
SELECT GROUP BY INSERT, UPDATE, DELETE
Функции
Зачастую встаёт задача не просто по выборке каких-либоданных из таблицы, а по их подсчёту.Пример “раз”: есть таблица учеников students. Сколькоучеников имеет оценку 5?Пример “два”: какой максимальный балл набрал ученик затест?Пример “три”: чему равен средний балл по контрольной?Пример “четыре”: сколько пользователей банка запоследний месяц воспользовались услугамиИнтернет–банкинга?Для работы со всем этим и применяются специальныефункции.
Информатика 10-11 классы Язык SQL
SELECT GROUP BY INSERT, UPDATE, DELETE
Функции
Функция Аргументы ОписаниеCOUNT(*) не важно считает количество записей в вы-
боркеMAX(mark) название
столбцанаходит максимальное значение встолбце среди выбранных записей
MIN(mark) названиестолбца
находит минимальное значение встолбце среди выбранных записей
SUM(mark) названиестолбца
находит сумму значений из столбцаmark среди выбранных записей
AVG(mark) названиестолбца
находит среднее арифметическоезначение в столбце среди выбран-ных записей
Информатика 10-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
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
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
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
SELECT GROUP BY INSERT, UPDATE, DELETE
GROUP BY
А что, если я хочу узнать, сколько учеников получилооценку 5, сколько 4, и т.п.?Конечно, можно выполнить ряд последовательныхзапросов с поиском через WHERE.Но есть альтернатива! — GROUP BY.Оператор GROUP BY группирует результаты по заданномуполю.
Информатика 10-11 классы Язык 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
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
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
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
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
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
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