https://tproger.ru/articles/sql-interview-questions/
- Что такое «SQL»?
- Какие существуют операторы SQL?
- Что означает
NULL
в SQL? - Что такое «временная таблица»? Для чего она используется?
- Что такое «представление» (view) и для чего оно применяется?
- Каков общий синтаксис оператора
SELECT
? - Что такое
JOIN
? - Какие существуют типы
JOIN
? - Что лучше использовать
JOIN
или подзапросы? - Для чего используется оператор
HAVING
? - В чем различие между операторами
HAVING
иWHERE
? - Для чего используется оператор
ORDER BY
? - Для чего используется оператор
GROUP BY
? - Как
GROUP BY
обрабатывает значениеNULL
? - В чем разница между операторами
GROUP BY
иDISTINCT
? - Перечислите основные агрегатные функции.
- В чем разница между
COUNT(*)
иCOUNT({column})
? - Что делает оператор
EXISTS
? - Для чего используются операторы
IN
,BETWEEN
,LIKE
? - Для чего применяется ключевое слово
UNION
? - Какие ограничения на целостность данных существуют в SQL?
- Какие отличия между ограничениями
PRIMARY
иUNIQUE
? - Может ли значение в столбце, на который наложено ограничение
FOREIGN KEY
, равнятьсяNULL
? - Как создать индекс?
- Что делает оператор
MERGE
? - В чем отличие между операторами
DELETE
иTRUNCATE
? - Что делает оператор
EXPLAIN
? - Что такое «RETURNING»?
- Что такое «хранимая процедура»?
- Что такое «триггер»?
- Что такое «курсор»?
- Опишите разницу типов данных
DATETIME
иTIMESTAMP
. - Для каких числовых типов недопустимо использовать операции сложения/вычитания?
- Какое назначение у операторов
PIVOT
иUNPIVOT
в Transact-SQL? - Расскажите об основных функциях ранжирования в Transact-SQL.
- Для чего используются операторы
INTERSECT
,EXCEPT
в Transact-SQL? - Напишите запрос...
SQL, Structured query language («язык структурированных запросов») — формальный непроцедурный язык программирования, применяемый для создания, модификации и управления данными в произвольной реляционной базе данных, управляемой соответствующей системой управления базами данных (СУБД).
Формальный - множество конечных слов (строк, цепочек) над конечным алфавитом. Различают языки естественные, на которых общаются люди, и искусственные (или формальные).
Непроцедурный - каждый оператор выдает результат, соответствующий запрашиваемому выходу. Ответственность за то, как добиться соответствующего выхода, лежит, в значительной степени, на моторе (движке) базы данных.
операторы определения данных (Data Definition Language, DDL):
CREATE
создает объект БД (базу, таблицу, представление, пользователя и т. д.),ALTER
изменяет объект,DROP
удаляет объект,TRUNCATE
- удаляет таблицу и создает ее заново. Причем если на эту таблицу есть ссылкиFOREGIN KEY
или таблица используется в репликации, то пересоздать такую таблицу не получится.RENAME
переименовыывает объект;
операторы манипуляции данными (Data Manipulation Language, DML):
SELECT
выбирает данные, удовлетворяющие заданным условиям,INSERT
добавляет новые данные,UPDATE
изменяет существующие данные,DELETE
удаляет данные;
операторы определения доступа к данным (Data Control Language, DCL):
GRANT
предоставляет пользователю (группе) разрешения на определенные операции с объектом,REVOKE
отзывает ранее выданные разрешения,DENY
задает запрет, имеющий приоритет над разрешением;
операторы управления транзакциями (Transaction Control Language, TCL):
COMMIT
применяет транзакцию,ROLLBACK
откатывает все изменения, сделанные в контексте текущей транзакции,SAVEPOINT
разбивает транзакцию на более мелкие.
NULL
- специальное значение (псевдозначение), которое может быть записано в поле таблицы базы данных. NULL соответствует понятию «пустое поле», то есть «поле, не содержащее никакого значения».
NULL
означает отсутствие, неизвестность информации. Значение NULL
не является значением в полном смысле слова: по определению оно означает отсутствие значения и не принадлежит ни одному типу данных. Поэтому NULL
не равно ни логическому значению FALSE
, ни пустой строке, ни 0
. При сравнении NULL
с любым значением будет получен результат NULL
, а не FALSE
и не 0
. Более того, NULL
не равно NULL
!
Временная таблица - это объект базы данных, который хранится и управляется системой базы данных на временной основе. Они могут быть локальными или глобальными. Используется для сохранения результатов вызова хранимой процедуры, уменьшение числа строк при соединениях, агрегирование данных из различных источников или как замена курсоров и параметризованных представлений.
Представление, View - виртуальная таблица, представляющая данные одной или более таблиц альтернативным образом. Представления широко используются когда необходимо представить структуру базы данных в удобном для восприятия человеком виде, а так же в соображениях безопасности, предоставляя пользователям возможность обращаться к данным, но не разрешая им доступ к исходным таблицам.
В действительности представление – всего лишь результат выполнения оператора SELECT
, который хранится в структуре памяти, напоминающей SQL таблицу. Они работают в запросах и операторах DML точно также как и основные таблицы, но не содержат никаких собственных данных. Представления значительно расширяют возможности управления данными. Это способ дать публичный доступ к некоторой (но не всей) информации в таблице.
Для создания представления используется оператор SQL CREATE и синтаксис выглядит следующим образом:
CREATE VIEW view_name
AS SELECT column_name
FROM table_name
WHERE condition
SELECT
- оператор DML SQL, возвращающий набор данных (выборку) из базы данных, удовлетворяющих заданному условию. Имеет следующую структуру:
SELECT
[DISTINCT | DISTINCTROW | ALL]
select_expression,...
FROM table_references
[WHERE where_definition]
[GROUP BY {unsigned_integer | column | formula}]
[HAVING where_definition]
[ORDER BY {unsigned_integer | column | formula} [ASC | DESC], ...]
JOIN - оператор языка SQL, который является реализацией операции соединения реляционной алгебры. Предназначен для обеспечения выборки данных из двух таблиц и включения этих данных в один результирующий набор.
Особенностями операции соединения являются следующее:
- в схему таблицы-результата входят столбцы обеих исходных таблиц (таблиц-операндов), то есть схема результата является «сцеплением» схем операндов;
- каждая строка таблицы-результата является «сцеплением» строки из одной таблицы-операнда со строкой второй таблицы-операнда;
- при необходимости соединения не двух, а нескольких таблиц, операция соединения применяется несколько раз (последовательно).
SELECT
field_name [,... n]
FROM
Table1
{INNER | {LEFT | RIGHT | FULL} OUTER | CROSS } JOIN
Table2
{ON <condition> | USING (field_name [,... n])}
(INNER) JOIN Результатом объединения таблиц являются записи, общие для левой и правой таблиц. Порядок таблиц для оператора не важен, поскольку оператор является симметричным.
LEFT (OUTER) JOIN
Производит выбор всех записей первой таблицы и соответствующих им записей второй таблицы. Если записи во второй таблице не найдены, то вместо них подставляется пустой результат (NULL
). Порядок таблиц для оператора важен, поскольку оператор не является симметричным.
RIGHT (OUTER) JOIN
LEFT JOIN
с операндами, расставленными в обратном порядке. Порядок таблиц для оператора важен, поскольку оператор не является симметричным.
FULL (OUTER) JOIN Результатом объединения таблиц являются все записи, которые присутствуют в таблицах. Порядок таблиц для оператора не важен, поскольку оператор является симметричным.
CROSS JOIN (декартово произведение) При выборе каждая строка одной таблицы объединяется с каждой строкой второй таблицы, давая тем самым все возможные сочетания строк двух таблиц. Порядок таблиц для оператора не важен, поскольку оператор является симметричным.
Обычно лучше использовать JOIN
, поскольку в большинстве случаев он более понятен и лучше оптимизируется СУБД (но 100% этого гарантировать нельзя). Так же JOIN
имеет заметное преимущество над подзапросами в случае, когда список выбора SELECT
содержит столбцы более чем из одной таблицы.
Подзапросы лучше использовать в случаях, когда нужно вычислять агрегатные значения и использовать их для сравнений во внешних запросах.
HAVING
используется для фильтрации результата GROUP BY
по заданным логическим условиям.
WHERE
- это ограничивающее выражение. Оно выполняется до того, как будет получен результат операции. WHERE служит для задания дополнительного условия выборки, операций вставки, редактирования и удаления записей. Условие (condition) может включать в себя предикаты AND, OR, NOT, LIKE, BETWEEN, IS, IN, ключевое слово NULL, операторы сравнения и равенства (<, >, =).
SELECT * FROM Planets WHERE Radius BETWEEN 3000 AND 9000
HAVING
- Оператор SQL HAVING является указателем на результат выполнения агрегатных функций. Агрегатной функцией в языке SQL называется функция, возвращающая какое-либо одно значение по набору значений столбца. Такими функциями являются: SQL COUNT(), SQL MIN(), SQL MAX(), SQL AVG(), SQL SUM().
SELECT Singer, SUM(Sale)
FROM Artists
GROUP BY Singer
HAVING SUM(Sale) > 2000000
Выражения WHERE используются вместе с операциями SELECT, UPDATE, DELETE, в то время как HAVING только с SELECT и предложением GROUP BY.
ORDER BY упорядочивает вывод запроса согласно значениям в том или ином количестве выбранных столбцов. Многочисленные столбцы упорядочиваются один внутри другого. Возможно определять возрастание ASC
или убывание DESC
для каждого столбца. По умолчанию установлено - возрастание.
GROUP BY
используется для агрегации записей результата по заданному столбцу.
При использовании GROUP BY
все значения NULL
считаются равными.
DISTINCT
указывает, что для вычислений используются только уникальные значения столбца. NULL
считается как отдельное значение. DISTINCT нашел широкое применение в операторе SQL SELECT, для выборки уникальных значений. Так же используется в агрегатных функциях.
SELECT DISTINCT column_name FROM table_name
GROUP BY
используется для объединения результатов выборки по одному или нескольким столбцам. создает отдельную группу для всех возможных значений (включая значение NULL
).
Если нужно удалить только дубликаты лучше использовать DISTINCT
, GROUP BY
лучше использовать для определения групп записей, к которым могут применяться агрегатные функции.
Агрегатных функции - функции, которые берут группы значений и сводят их к одиночному значению.
SQL предоставляет несколько агрегатных функций:
COUNT
- производит подсчет записей, удовлетворяющих условию запроса;
SUM
- вычисляет арифметическую сумму всех значений колонки;
AVG
- вычисляет среднее арифметическое всех значений;
MAX
- определяет наибольшее из всех выбранных значений;
MIN
- определяет наименьшее из всех выбранных значений.
COUNT (*)
подсчитывает количество записей в таблице, не игнорируя значение NULL, поскольку эта функция оперирует записями, а не столбцами.
COUNT ({column})
подсчитывает количество значений в {column}
. При подсчете количества значений столбца эта форма функции COUNT
не принимает во внимание значение NULL
.
EXISTS
берет подзапрос, как аргумент, и оценивает его как TRUE
, если подзапрос возвращает какие-либо записи и FALSE
, если нет.
IN
- определяет набор значений.
SELECT * FROM Persons WHERE name IN ('Ivan','Petr','Pavel');
BETWEEN
определяет диапазон значений. В отличие от IN
, BETWEEN
чувствителен к порядку, и первое значение в предложении должно быть первым по алфавитному или числовому порядку.
SELECT * FROM Persons WHERE age BETWEEN 20 AND 25;
LIKE
применим только к полям типа CHAR
или VARCHAR
, с которыми он используется чтобы находить подстроки. В качестве условия используются символы шаблонизации (wildkards) - специальные символы, которые могут соответствовать чему-нибудь:
-
_
замещает любой одиночный символ. Например,'b_t'
будет соответствовать словам'bat'
или'bit'
, но не будет соответствовать'brat'
. -
%
замещает последовательность любого числа символов. Например'%p%t'
будет соответствовать словам'put'
,'posit'
, или'opt'
, но не'spite'
.
SELECT * FROM UNIVERSITY WHERE NAME LIKE '%o';
В языке SQL ключевое слово UNION
применяется для объединения результатов двух SQL-запросов в единую таблицу, состоящую из схожих записей. Оба запроса должны возвращать одинаковое число столбцов и совместимые типы данных в соответствующих столбцах. Необходимо отметить, что UNION
сам по себе не гарантирует порядок записей. Записи из второго запроса могут оказаться в начале, в конце или вообще перемешаться с записями из первого запроса. В случаях, когда требуется определенный порядок, необходимо использовать ORDER BY
.
С удалением дублей:
SELECT * FROM имя_таблицы1 WHERE условие
UNION SELECT * FROM имя_таблицы2 WHERE условие
Без удаления дублей:
SELECT * FROM имя_таблицы1 WHERE условие
UNION ALL SELECT * FROM имя_таблицы2 WHERE условие
Можно объединять не две таблицы, а три или более:
SELECT * FROM имя_таблицы1 WHERE условие
UNION SELECT * FROM имя_таблицы2 WHERE условие
UNION SELECT * FROM имя_таблицы3 WHERE условие
UNION SELECT * FROM имя_таблицы4 WHERE услови
sql constraint
PRIMARY KEY
- набор полей (1 или более), значения которых образуют уникальную комбинацию и используются для однозначной идентификации записи в таблице. Для таблицы может быть создано только одно такое ограничение. Данное ограничение используется для обеспечения целостности сущности, которая описана таблицей.
CHECK
используется для ограничения множества значений, которые могут быть помещены в данный столбец. Это ограничение используется для обеспечения целостности предметной области, которую описывают таблицы в базе.
UNIQUE
обеспечивает отсутствие дубликатов в столбце или наборе столбцов.
FOREIGN KEY
защищает от действий, которые могут нарушить связи между таблицами. FOREIGN KEY
в одной таблице указывает на PRIMARY KEY
в другой. Поэтому данное ограничение нацелено на то, чтобы не было записей FOREIGN KEY
, которым не отвечают записи PRIMARY KEY
.
По умолчанию ограничение PRIMARY
создает кластерный индекс на столбце, а UNIQUE
- некластерный. Другим отличием является то, что PRIMARY
не разрешает NULL
записей, в то время как UNIQUE
разрешает одну (а в некоторых СУБД несколько) NULL
запись.
Может, если на данный столбец не наложено ограничение NOT NULL
.
Индекс можно создать либо с помощью выражения CREATE INDEX
:
CREATE INDEX index_name ON table_name (column_name)
либо указав ограничение целостности в виде уникального UNIQUE
или первичного PRIMARY
ключа в операторе создания таблицы CREATE TABLE
.
MERGE
позволяет осуществить слияние данных одной таблицы с данными другой таблицы. При слиянии таблиц проверяется условие, и если оно истинно, то выполняется UPDATE
, а если нет - INSERT
. При этом изменять поля таблицы в секции UPDATE
, по которым идет связывание двух таблиц, нельзя.
DELETE
- оператор DML, удаляет записи из таблицы, которые удовлетворяют критерию WHERE
при этом задействуются триггеры, ограничения и т.д.
TRUNCATE
- DDL оператор. удаляет таблицу (для мгновенной очистки всех строк) и создает ее заново. Причем если на эту таблицу есть ссылки FOREGIN KEY
или таблица используется в репликации, то пересоздать такую таблицу не получится.
- Оператор SQL TRUNCATE не ведет запись об удаленных данных в журнал событий.
- SQL DELETE осуществляет блокировку построчно, оператор SQL TRUNCATE по всей странице целиком. Вследствие этого, оператор SQL TRUNCATE не возвращает никакого значения, SQL DELETE же, возвращает количество удаленных строк.
- После применения оператора SQL DELETE возможно сделать откат операции и восстановить удаленные данные (команда ROLLBACK). При применении оператора SQL TRUNCATE этого сделать нельзя, однако в СУБД MS SQL Server, оператор может применяться в транзакциях.
EXPLAIN имя_таблицы
EXPLAIN SELECT опции_выборки
Если оператор SELECT предваряется ключевым словом EXPLAIN, MySQL сообщит о том, как будет производиться обработка SELECT, и предоставит информацию о порядке и методе связывания таблиц.
При помощи EXPLAIN можно выяснить, когда стоит снабдить таблицы индексами, чтобы получить более быструю выборку, использующую индексы для поиска записей. Кроме того, можно проверить, насколько удачный порядок связывания таблиц был выбран оптимизатором. Заставить оптимизатор связывать таблицы в заданном порядке можно при помощи указания STRAIGHT_JOIN.
Для непростых соединений EXPLAIN возвращает строку информации о каждой из использованных в работе оператора SELECT таблиц. Таблицы перечисляются в том порядке, в котором они будут считываться. MySQL выполняет все связывания за один проход (метод называется "single-sweep multi-join"). Делается это так: MySQL читает строку из первой таблицы, находит совпадающую строку во второй таблице, затем - в третьей, и так далее. Когда обработка всех таблиц завершается, MySQL выдает выбранные столбцы и обходит в обратном порядке список таблиц до тех пор, пока не будет найдена таблица с наибольшим совпадением строк. Следующая строка считывается из этой таблицы и процесс продолжается в следующей таблице.
********************** 1. row **********************
id: 1
select_type: SIMPLE
table: categories
type: ALL
possible_keys: NULL
key: NULL
key_len: NULL
ref: NULL
rows: 4
Extra:
1 row in set (0.00 sec)
-
id – порядковый номер для каждого SELECT’а внутри запроса (когда имеется несколько подзапросов) select_type – тип запроса SELECT.
-
SIMPLE — Простой запрос SELECT без подзапросов или UNION’ов
-
PRIMARY – данный SELECT – самый внешний запрос в JOIN’е
-
DERIVED – данный SELECT является частью подзапроса внутри FROM
-
SUBQUERY – первый SELECT в подзапросе
-
DEPENDENT SUBQUERY – подзапрос, который зависит от внешнего запроса
-
UNCACHABLE SUBQUERY – не кешируемый подзапрос (существуют определенные условия для того, чтобы запрос кешировался)
-
UNION – второй или последующий SELECT в UNION’е
-
DEPENDENT UNION – второй или последующий SELECT в UNION’е, зависимый от внешнего запроса
-
UNION RESULT – результат UNION’а
-
Table – таблица, к которой относится выводимая строка
-
Type — указывает на то, как MySQL связывает используемые таблицы. Это одно из наиболее полезных полей в выводе потому, что может сообщать об отсутствующих индексах или почему написанный запрос должен быть пересмотрен и переписан. Возможные значения:
-
System – таблица имеет только одну строку
-
Const – таблица имеет только одну соответствующую строку, которая проиндексирована. Это наиболее быстрый тип соединения потому, что таблица читается только один раз и значение строки может восприниматься при дальнейших соединениях как константа.
-
Eq_ref – все части индекса используются для связывания. Используемые индексы: PRIMARY KEY или UNIQUE NOT NULL. Это еще один наилучший возможный тип связывания.
-
Ref – все соответствующие строки индексного столбца считываются для каждой комбинации строк из предыдущей таблицы. Этот тип соединения для индексированных столбцов выглядит как использование операторов = или < = >
-
Fulltext – соединение использует полнотекстовый индекс таблицы
-
Ref_or_null – то же самое, что и ref, но также содержит строки со значением null для столбца
-
Index_merge – соединение использует список индексов для получения результирующего набора. Столбец key вывода команды EXPLAIN будет содержать список использованных индексов.
-
Unique_subquery – подзапрос IN возвращает только один результат из таблицы и использует первичный ключ.
-
Index_subquery – тоже, что и предыдущий, но возвращает более одного результата.
-
Range – индекс, использованный для нахождения соответствующей строки в определенном диапазоне, обычно, когда ключевой столбец сравнивается с константой, используя операторы вроде: BETWEEN, IN, >, >=, etc.
-
Index – сканируется все дерево индексов для нахождения соответствующих строк.
-
All – Для нахождения соответствующих строк используются сканирование всей таблицы. Это наихудший тип соединения и обычно указывает на отсутствие подходящих индексов в таблице.
-
Possible_keys – показывает индексы, которые могут быть использованы для нахождения строк в таблице. На практике они могут использоваться, а могут и не использоваться. Фактически, этот столбец может сослужить добрую службу в деле оптимизации запросов, т.к значение NULL указывает на то, что не найдено ни одного подходящего индекса .
-
Key– указывает на использованный индекс. Этот столбец может содержать индекс, не указанный в столбце possible_keys. В процессе соединения таблиц оптимизатор ищет наилучшие варианты и может найти ключи, которые не отображены в possible_keys, но являются более оптимальными для использования.
-
Key_len – длина индекса, которую оптимизатор MySQL выбрал для использования. Например, значение key_len, равное 4, означает, что памяти требуется для хранения 4 знаков. На эту тему вот cсылка
-
Ref – указываются столбцы или константы, которые сравниваются с индексом, указанным в поле key. MySQL выберет либо значение константы для сравнения, либо само поле, основываясь на плане выполнения запроса.
-
Rows – отображает число записей, обработанных для получения выходных данных. Это еще одно очень важное поле, которое дает повод оптимизировать запросы, особенно те, которые используют JOIN’ы и подзапросы.
-
Extra – содержит дополнительную информацию, относящуюся к плану выполнения запроса. Такие значения как “Using temporary”, “Using filesort” и т.д могут быть индикатором проблемного запроса. С полным списком возможных значений вы можете ознакомиться здесь
Иногда бывает полезно получать данные из модифицируемых строк в процессе их обработки. Это возможно с использованием предложения RETURNING, которое можно задать для команд INSERT, UPDATE и DELETE. Применение RETURNING позволяет обойтись без дополнительного запроса к базе для сбора данных и это особенно ценно, когда как-то иначе трудно получить изменённые строки надёжным образом.
Точно работает в PostgreSQL
INSERT INTO users (firstname, lastname) VALUES ('Joe', 'Cool') RETURNING id;
В команде UPDATE данные, выдаваемые в RETURNING, образуются новым содержимым изменённой строки. Например:
UPDATE products SET price = price * 1.10
WHERE price <= 99.99
RETURNING name, price AS new_price;
В команде DELETE данные, выдаваемые в RETURNING, образуются содержимым удалённой строки. Например:
DELETE FROM products
WHERE obsoletion_date = 'today'
RETURNING *;
Хранимая процедура — объект базы данных, представляющий собой набор SQL-инструкций, который хранится на сервере. Хранимые процедуры очень похожи на обыкновенные процедуры языков высокого уровня, у них могут быть входные и выходные параметры и локальные переменные, в них могут производиться числовые вычисления и операции над символьными данными, результаты которых могут присваиваться переменным и параметрам. В хранимых процедурах могут выполняться стандартные операции с базами данных (как DDL, так и DML). Кроме того, в хранимых процедурах возможны циклы и ветвления, то есть в них могут использоваться инструкции управления процессом исполнения.
Хранимые процедуры позволяют повысить производительность, расширяют возможности программирования и поддерживают функции безопасности данных. В большинстве СУБД при первом запуске хранимой процедуры она компилируется (выполняется синтаксический анализ и генерируется план доступа к данным) и в дальнейшем её обработка осуществляется быстрее.
Триггер (trigger) — это хранимая процедура особого типа, которую пользователь не вызывает непосредственно, а исполнение которой обусловлено действием по модификации данных: добавлением, удалением или изменением данных в заданной таблице реляционной базы данных. Триггеры применяются для обеспечения целостности данных и реализации сложной бизнес-логики. Триггер запускается сервером автоматически и все производимые им модификации данных рассматриваются как выполняемые в транзакции, в которой выполнено действие, вызвавшее срабатывание триггера. Соответственно, в случае обнаружения ошибки или нарушения целостности данных может произойти откат этой транзакции.
Момент запуска триггера определяется с помощью ключевых слов BEFORE
(триггер запускается до выполнения связанного с ним события) или AFTER
(после события). В случае, если триггер вызывается до события, он может внести изменения в модифицируемую событием запись. Кроме того, триггеры могут быть привязаны не к таблице, а к представлению (VIEW). В этом случае с их помощью реализуется механизм «обновляемого представления». В этом случае ключевые слова BEFORE
и AFTER
влияют лишь на последовательность вызова триггеров, так как собственно событие (удаление, вставка или обновление) не происходит.
Курсор — это объект базы данных, который позволяет приложениям работать с записями «по-одной», а не сразу с множеством, как это делается в обычных SQL командах.
Порядок работы с курсором такой:
- Определить курсор (
DECLARE
) - Открыть курсор (
OPEN
) - Получить запись из курсора (
FETCH
) - Обработать запись...
- Закрыть курсор (
CLOSE
) - Удалить ссылку курсора (
DEALLOCATE
). Когда удаляется последняя ссылка курсора, SQL освобождает структуры данных, составляющие курсор.
DATETIME
предназначен для хранения целого числа: YYYYMMDDHHMMSS
. И это время не зависит от временной зоны настроенной на сервере.
Размер: 8 байт
TIMESTAMP
хранит значение равное количеству секунд, прошедших с полуночи 1 января 1970 года по усреднённому времени Гринвича. При получении из базы отображается с учётом часового пояса. Размер: 4 байта
В качестве операндов операций сложения и вычитания нельзя использовать числовой тип BIT
.
PIVOT
и UNPIVOT
являются нестандартными реляционными операторами, которые поддерживаются Transact-SQL.
Оператор PIVOT
разворачивает возвращающее табличное значение выражение, преобразуя уникальные значения одного столбца выражения в несколько выходных столбцов, а также, в случае необходимости, объединяет оставшиеся повторяющиеся значения столбца и отображает их в выходных данных. Оператор UNPIVOT
производит действия, обратные PIVOT
, преобразуя столбцы возвращающего табличное значение выражения в значения столбца.
Ранжирующие функции - это функции, которые возвращают значение для каждой записи группы в результирующем наборе данных. На практике они могут быть использованы, например, для простой нумерации списка, составления рейтинга или постраничной навигации.
ROW_NUMBER
– функция нумерации в Transact-SQL, которая возвращает просто номер записи.
RANK
возвращает ранг каждой записи. В данном случае, в отличие от ROW_NUMBER
, идет уже анализ значений и в случае нахождения одинаковых возвращает одинаковый ранг с пропуском следующего.
DENSE_RANK
так же возвращает ранг каждой записи, но в отличие от RANK
в случае нахождения одинаковых значений возвращает ранг без пропуска следующего.
NTILE
– функция Transact-SQL, которая делит результирующий набор на группы по определенному столбцу.
Оператор EXCEPT
возвращает уникальные записи из левого входного запроса, которые не выводятся правым входным запросом.
Оператор INTERSECT
возвращает уникальные записи, выводимые левым и правым входными запросами.
CREATE TABLE table (
id BIGINT(20) NOT NULL AUTO_INCREMENT,
created TIMESTAMP NOT NULL DEFAULT 0,
PRIMARY KEY (id)
);
Требуется написать запрос который вернет максимальное значение id
и значение created
для этого id
:
SELECT id, created FROM table where id = (SELECT MAX(id) FROM table);
CREATE TABLE track_downloads (
download_id BIGINT(20) NOT NULL AUTO_INCREMENT,
track_id INT NOT NULL,
user_id BIGINT(20) NOT NULL,
download_time TIMESTAMP NOT NULL DEFAULT 0,
PRIMARY KEY (download_id)
);
Напишите SQL-запрос, возвращающий все пары (download_count, user_count)
, удовлетворяющие следующему условию: user_count
— общее ненулевое число пользователей, сделавших ровно download_count
скачиваний 19 ноября 2010 года
:
SELECT DISTINCT download_count, COUNT(*) AS user_count
FROM (
SELECT COUNT(*) AS download_count
FROM track_downloads WHERE download_time="2010-11-19"
GROUP BY user_id)
AS download_count
GROUP BY download_count;