ВУЗ: Не указан

Категория: Не указан

Дисциплина: Не указана

Добавлен: 01.12.2023

Просмотров: 424

Скачиваний: 2

ВНИМАНИЕ! Если данный файл нарушает Ваши авторские права, то обязательно сообщите нам.

Переупорядочивание
(reordering).
Для увеличения производительности процессор/компилятор могут переставлять местами некоторые инструкции/операции.
Процессор может решить поменять порядок выполнения операций, если, например, сочтет,
что такая последовательность выполнится быстрее. Эффект может наблюдаться, когда один поток кладет результаты первой операции в регистр или локальный кеш, а результат второй операции попадает непосредственно в основную память. Тогда второй поток, обращаясь к основной памяти, может сначала увидеть результат второй операции и только потом первой,
когда все регистры или кеши синхронизируются с основной памятью.
Также регулируется набором правил «happens-before»: операции чтения и записи volatile переменных не могут быть переупорядочены с операциями чтения и записи других volatile и не volatile переменных.
https://habr.com/ru/company/golovachcourses/blog/221133/

SQL
Что такое DDL? Какие операции в него входят? Рассказать про них
Операторы определения данных (Data Definition Language, DDL):

CREATE создает объект БД (базу, таблицу, представление, пользователя и т. д.);

ALTER изменяет объект;

DROP удаляет объект;

TRUNCATE удаляет таблицу и создает ее пустую заново, но если в таблице были foreigh key, то создать таблицу не получится, rollback после TRUNCATE невозможен.
Что такое DML? Какие операции в него входят? Рассказать про них
Операторы манипуляции данными (Data Manipulation Language, DML):

SELECT выбирает данные, удовлетворяющие заданным условиям;

INSERT добавляет новые данные;

UPDATE изменяет существующие данные;

DELETE удаляет данные при выполнении условия WHERE;
Что такое TCL? Какие операции в него входят? Рассказать про них
Операторы управления транзакциями (Transaction Control Language, TCL):

BEGIN служит для определения начала транзакции;

COMMIT применяет транзакцию;

ROLLBACK откатывает все изменения, сделанные в контексте текущей транзакции;

SAVEPOINT разбивает транзакцию на более мелкие.
SetTransaction –
Что такое DCL? Какие операции в него входят? Рассказать про них
Операторы определения доступа к данным (Data Control Language, DCL):

GRANT предоставляет пользователю (группе) разрешения на определенные операции с объектом;

REVOKE отзывает ранее выданные разрешения;

DENY задает запрет, имеющий приоритет над разрешением.
Нюансы работы с NULL в SQL. Как проверить поле на NULL?
NULLспециальное значение (псевдозначение), которое может быть записано в поле таблицы базы данных. NULL соответствует понятию «пустое поле», то есть «поле, не содержащее никакого значения».
NULL означает отсутствие, неизвестность информации. Значение NULL не является значением в полном смысле слова: по определению оно означает отсутствие значения и не принадлежит ни одному типу данных. Поэтому NULL не равно ни логическому значению


FALSE, ни пустой строке, ни 0. При сравнении NULL с любым значением будет получен
результат NULL, а не FALSE и не 0. Более того, NULL не равно NULL!
Команды: IS NULL, IS NOT NULL.
Виды Join’ов?
JOIN – оператор языка SQL, который является реализацией операции соединения реляционной алгебры. Предназначен для обеспечения выборки данных из двух таблиц и включения этих данных в один результирующий набор.
Особенностями операции соединения являются следующее:

в схему таблицы-результата входят столбцы обеих исходных таблиц (таблиц- операндов), то есть схема результата является «сцеплением» схем операндов;

каждая строка таблицы-результата является «сцеплением» строки из одной таблицы- операнда со строкой второй таблицы-операнда;

при необходимости соединения не двух, а нескольких таблиц, операция соединения применяется несколько раз (последовательно).
SELECT
field_name [,... n]
FROM
Table1
{INNER | {LEFT | RIGHT | FULL} OUTER | CROSS } JOIN
Table2
{ON | USING (field_name [,... n])}
Какие существуют типы JOIN?

(INNER) JOIN Результатом объединения таблиц являются записи, общие для левой и правой таблиц. Порядок таблиц для оператора не важен, поскольку оператор является симметричным.

LEFT (OUTER) JOIN. Производит выбор всех записей первой таблицы и соответствующих им записей второй таблицы. Если записи во второй таблице не найдены, то вместо них подставляется пустой результат (NULL). Порядок таблиц для оператора важен, поскольку оператор не является симметричным.

RIGHT (OUTER) JOIN с операндами, расставленными в обратном порядке. Порядок таблиц для оператора важен, поскольку оператор не является симметричным.

FULL (OUTER) JOIN. Результатом объединения таблиц являются все записи, которые присутствуют в таблицах. Порядок таблиц для оператора не важен, поскольку оператор является симметричным.

CROSS JOIN (декартово произведение) При выборе каждая строка одной таблицы объединяется с каждой строкой второй таблицы, давая тем самым все возможные сочетания строк двух таблиц. Порядок таблиц для оператора не важен, поскольку оператор является симметричным.

Что лучше использовать join или подзапросы? Почему?
Обычно лучше использовать JOIN, поскольку в большинстве случаев он более понятен и лучше оптимизируется СУБД (но 100% этого гарантировать нельзя). Так же JOIN имеет заметное преимущество над подзапросами в случае, когда список выбора SELECT содержит столбцы более чем из одной таблицы.
Подзапросы лучше использовать в случаях, когда нужно вычислять агрегатные значения и использовать их для сравнений во внешних запросах.
Что делает UNION?
В языке SQL ключевое слово UNION применяется для объединения результатов двух SQL- запросов в единую таблицу, состоящую из схожих записей. Оба запроса должны возвращать одинаковое число столбцов и совместимые типы данных в соответствующих столбцах.
Необходимо отметить, что UNION сам по себе не гарантирует порядок записей. Записи из второго запроса могут оказаться в начале, в конце или вообще перемешаться с записями из первого запроса. В случаях, когда требуется определенный порядок, необходимо использовать ORDER BY.
Разница между UNION и UNION ALL заключается в том, что UNION будет пропускать дубликаты записей, тогда как UNION ALL будет включать дубликаты записей.
Чем WHERE отличается от HAVING (ответа про то, что используются в
разных частях запроса недостаточно)?
WHERE нельзя использовать с агрегатными функциями, HAVING можно (предикаты тоже).
В HAVING можно использовать псевдонимы, только если они используются для наименования результата агрегатной функции, в WHERE можно всегда.
HAVING стоит после GROUP BY, но может использоваться и без него. При отсутствии предложения GROUP BY агрегатные функции применяются ко всему выходному набору строк запроса, т. е. в результате получим всего одну строку, если выходной набор не пуст.
Что такое ORDER BY?
ORDER BY упорядочивает вывод запроса согласно значениям в том или ином количестве выбранных столбцов. Многочисленные столбцы упорядочиваются один внутри другого.
Возможно определять возрастание ASC или убывание DESC для каждого столбца. По умолчанию установлено возрастание.
Что такое GROUP BY?
GROUP BY используется для агрегации записей результата по заданным атрибутам.
Создает отдельную группу для всех возможных значений (включая значение NULL).
При использовании GROUP BY все значения NULL считаются равными.
Что такое DISTINCT?
DISTINCT указывает, что для вычислений используются только уникальные значения столбца.
Что такое LIMIT?
Ограничивает выборку заданным числом.


Что такое EXISTS?
EXISTS берет подзапрос, как аргумент, и оценивает его как TRUE, если подзапрос возвращает какие-либо записи, и FALSE, если нет.
Расскажите про операторы IN, BETWEEN, LIKE

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';
Что делает оператор MERGE? Какие у него есть ограничения?
MERGE позволяет осуществить слияние данных одной таблицы с данными другой таблицы.
При слиянии таблиц проверяется условие, и если оно истинно, то выполняется UPDATE, а если нет – INSERT. При этом изменять поля таблицы в секции UPDATE, по которым идет связывание двух таблиц, нельзя.
MERGE Ships AS t -- таблица, которая будет меняться
USING (SELECT запрос ) AS s ON (t.name = s.ship) – условие слияния
THEN UPDATE SET t.launched = s.year – обновление
WHEN NOT MATCHED – если условие не выполняется
THEN INSERT VALUES(s.ship, s.year) – вставка
Какие агрегатные функции вы знаете?
Агрегатных функции – функции, которые берут группы значений и сводят их к одиночному значению.
Несколько агрегатных функций:

COUNT производит подсчет записей, удовлетворяющих условию запроса;

CONCUT соединяет строки;

SUM вычисляет арифметическую сумму всех значений колонки;

AVG вычисляет среднее арифметическое всех значений;


MAX определяет наибольшее из всех выбранных значений;

MIN определяет наименьшее из всех выбранных значений.
Что такое ограничения (constraints)? Какие вы знаете?
Ограничения – это ключевые слова, которые помогают установить правила размещения данных в базе. Используются при создании БД.
NOT NULL указывает, что значение не может быть пустым.
UNIQUE обеспечивает отсутствие дубликатов.
PRIMARY KEY – комбинация NOT NULL и UNIQUE. Помечает каждую запись в базе данных уникальным значением.
CHECK проверяет, вписывается ли значение в заданный диапазон (s_id int CHECK(s_id > 0)).
FOREIGN KEY создает связь между двумя таблицами и защищает от действий, которые могут нарушить связи между таблицами. FOREIGN KEY в одной таблице указывает на
PRIMARY KEY в другой.
DEFAULT устанавливает значение по умолчанию, если значения не предоставлено (name
VARCHAR(20) DEFAULT 'noname').
Какие отличия между PRIMARY и UNIQUE?
По умолчанию PRIMARY создает кластерный индекс на столбце, а UNIQUE – некластерный.
PRIMARY не разрешает NULL записей, в то время как UNIQUE разрешает одну (а в некоторых СУБД несколько) NULL запись.
Таблица может иметь один PRIMARY KEY и много UNIQUE.
Может ли значение в столбце, на который наложено ограничение FOREIGN
KEY, равняться NULL?
Может, если на данный столбец не наложено ограничение NOT NULL.
Что такое суррогатные ключи?
Суррогатный ключ – это дополнительное служебное поле, автоматически добавленное к уже имеющимся информационным полям таблицы, предназначение которого – служить первичным ключом.
1   ...   13   14   15   16   17   18   19   20   ...   25

Что такое индексы? Какие они бывают?
Индексы относятся к методу настройки производительности, позволяющему быстрее извлекать записи из таблицы. Индекс создает структуру для индексируемого поля.
Необходимо просто добавить указатель индекса в таблицу.
Есть три типа индексов:
Уникальный индекс (Unique Index): этот индекс не позволяет полю иметь повторяющиеся значения. Если первичный ключ определен, уникальный индекс применен автоматически.
Кластеризованный индекс (Clustered Index): сортирует и хранит строки данных в таблицах или представлениях на основе их ключевых значений. Это ускоряет операции чтения из БД.

Некластеризованный индекс (Non-Clustered Index): внутри таблицы есть упорядоченный список, содержащий значения ключа некластеризованного индекса и указатель на строку данных, содержащую значение ключа. Каждый новый индекс увеличивает время,
необходимое для создания новых записей из-за упорядочивания. Каждая таблица может иметь много некластеризованных индексов.
Как создать индекс?

с помощью выражения CREATE INDEX:
CREATE INDEX index_name ON table_name (column_name)

указав ограничение целостности в виде уникального UNIQUE или первичного
PRIMARY ключа в операторе создания таблицы CREATE TABLE.
Имеет ли смысл индексировать данные, имеющие небольшое количество
возможных значений?
Примерное правило, которым можно руководствоваться при создании индекса: если объем информации (в байтах) НЕ удовлетворяющей условию выборки меньше, чем размер индекса
(в байтах) по данному условию выборки, то в общем случае оптимизация приведет к замедлению выборки.
Когда полное сканирование набора данных выгоднее доступа по индексу?
Полное сканирование производится многоблочным чтением. Сканирование по индексу –
одноблочным. При доступе по индексу сначала идет сканирование самого индекса, а затем чтение блоков из набора данных. Число блоков, которые надо при этом прочитать из набора зависит от фактора кластеризации. Если суммарная стоимость всех необходимых одноблочных чтений больше стоимости полного сканирования многоблочным чтением, то полное сканирование выгоднее и оно выбирается оптимизатором.
Таким образом, полное сканирование выбирается при слабой селективности предикатов запроса и/или слабой кластеризации данных, либо в случае очень маленьких наборов данных.
Чем TRUNCATE отличается от DELETE?
DELETE – оператор DML, удаляет записи из таблицы, которые удовлетворяют условиям
WHERE. Медленнее, чем TRUNCATE. Есть возможность восстановить данные.
TRUNCATE – DDL оператор, удаляет все строки из таблицы. Нет возможность восстановить данные – сделать ROLLBACK.
Что такое хранимые процедуры? Для чего они нужны?
Хранимая процедура – объект базы данных, представляющий собой набор SQL-
инструкций, который хранится на сервере.
Хранимые процедуры очень похожи на обыкновенные методы языков высокого уровня, у них могут быть входные и выходные параметры и локальные переменные, в них могут производиться числовые вычисления и операции над символьными данными, результаты которых могут присваиваться переменным и параметрам.


В хранимых процедурах могут выполняться стандартные операции с базами данных (как
DDL, так и DML). Кроме того, в хранимых процедурах возможны циклы и ветвления, то есть в них могут использоваться инструкции управления процессом исполнения.
Хранимые процедуры позволяют повысить производительность, расширяют возможности программирования и поддерживают функции безопасности данных.
В большинстве СУБД при первом запуске хранимой процедуры она компилируется
(выполняется синтаксический анализ и генерируется план доступа к данным) и в дальнейшем ее обработка осуществляется быстрее.
Что такое «триггер»?
Триггер (trigger) – это хранимая процедура особого типа, исполнение которой обусловлено действием по модификации данных: добавлением, удалением или изменением данных в заданной таблице реляционной базы данных. Триггер запускается сервером автоматически и все производимые им модификации данных рассматриваются как выполняемые в транзакции, в которой выполнено действие, вызвавшее срабатывание триггера.
Момент запуска триггера определяется с помощью ключевых слов BEFORE (триггер запускается до выполнения связанного с ним события) или AFTER (после события).
Что такое представления (VIEW)? Для чего они нужны?
View – виртуальная таблица, представляющая данные одной или более таблиц альтернативным образом.
В действительности представление – всего лишь результат выполнения оператора SELECT,
который хранится в структуре памяти, напоминающей SQL таблицу. Они работают в запросах и операторах DML точно так же, как и основные таблицы, но не содержат никаких собственных данных. Представления значительно расширяют возможности управления данными. Это способ дать публичный доступ к некоторой (но не всей) информации в таблице.
Представления могут основываться как на таблицах, так и на других представлениях, т. е.
могут быть вложенными (до 32 уровней вложенности).
Что такое временные таблицы? Для чего они нужны?
Подобные таблицы удобны для каких-то временных промежуточных выборок из нескольких таблиц.
Создание временной таблицы начинается со знака решетки #. Если используется один знак
#, то создается локальная таблица, которая доступна в течение текущей сессии. Ели используются два знака ##, то создается глобальная временная таблица. В отличие от локальной глобальная временная таблица доступна всем открытым сессиям базы данных.
CREATE TABLE #ProductSummary
(ProdId INT IDENTITY,
ProdName NVARCHAR(20),
Price MONEY)