Skip to content

Вопросы по SQL Server, задаваемые на интервью опытным разработчикам

Пересказ статьи Sergey Gigoyan. SQL Server interview questions for experienced developers


В этой статье приводятся 10 технических вопросов по SQL Server для старших разработчиков SQL Server и даются ответы на них с примерами. Хотя в интернете существуют сотни статей и публикаций в блогах, имеющих отношение к интервью по серверам SQL, я решил поделиться моим подходом к интервьюированию кандидатов на разработчика баз данных старшего уровня (senior).

Стояла задача задать минимальное число вопросов за ограниченное время (час или менее) и, в то же время, выбрать такие вопросы, которые в максимальной степени покроют основные темы разработки баз данных. Таким образом, вместо того, чтобы задавать несколько вопросов по одной теме, я попытался сформулировать вопросы так, чтобы каждый вопрос представлял целиком одну тему. Продолжить чтение "Вопросы по SQL Server, задаваемые на интервью опытным разработчикам"
Категории: T-SQL

Правила в PostgreSQL

Пересказ статьи sabyda. Rules in PostgreSQL


Иногда требуется выполнить различные/альтернативные действия во время запросов к базе данных. Нам может это потребоваться для защиты данных или их абстракции. Система правил (rule) PostgreSQL позволяет определить альтернативные действия на вставку, обновление или удаление. Правило генерирует дополнительный запрос. Как результат, выполнение правила оказывает влияние на производительность системы.
Продолжить чтение "Правила в PostgreSQL"

Почему табличный хинт XLOCK не работает?

Пересказ статьи DANIEL JANIK. Why is the XLOCK table hint broken?


Поговорим о том, для чего служит XLOCK. XLOCK - это табличный хинт, который может использоваться в запросе, чтобы наложить эксклюзивную блокировку на ресурсы, к которым обращается запрос. Он может быть весьма опасен, поскольку эксклюзивная блокировка на таблицу или раздел может вызвать значительную потерю производительности. Продолжить чтение "Почему табличный хинт XLOCK не работает?"
Категории: T-SQL

Краткое руководство по запуску кода Python в SQL Server

Пересказ статьи Emmitt Albright. A Quick Start to Running Python Code in SQL Server


В SQL Server 2016 была реализована идея выполнения скрипта на языке R изнутри SQL Server. В SQL Server 2017 эта возможность получила название Machine Learning Services (службы машинного обучения) и расширена возможностью выполнять код на языке Python. В этой статье дается краткое руководство по выполнению кода Python изнутри SQL Server и новым методам преобразования данных.
Продолжить чтение "Краткое руководство по запуску кода Python в SQL Server"

Какая разница между PERCENT_RANK и CUME_DIST?

Пересказ статьи Kathi Kellenberger. What’s the Difference Between PERCENT_RANK and CUME_DIST?


Помните стандартные тесты, которые вы сдавали в школе? Они сравнивали ваше выполнение с другими, ранжировали, но не давали фактического процента правильных ответов.

Microsoft реализовал несколько новых оконных функций в SQL Server 2012, в том числе две, которые сравнивают элементы в списке, аналогично результатам стандартных тестов. Этими двумя функциями являются PERCENT_RANK и CUME_DIST. Они подобны функции RANK, но возвращают процент в группе, а не просто ранговый номер.
Продолжить чтение "Какая разница между PERCENT_RANK и CUME_DIST?"
Категории: T-SQL

Какие столбцы находятся в этом индексе?

Пересказ статьи Erin Stellato. What columns are in that index?


Недавно я помогала с настройкой нескольким заказчикам, обычно означающая, что я просматриваю индексы и задаю вопросы. Я обратила внимание на шаблон, в котором столбцы кластеризованного индекса добавляются в определения ключей некластеризованных индексов. Это приводит к нескольким интересным моментам, когда дело доходит до создания некластеризованных индексов.

Продолжить чтение "Какие столбцы находятся в этом индексе?"

Понимание моделей восстановления SQL Server

Пересказ статьи Greg Larsen. Understanding SQL Server Recovery Models


Задачей номер 1, которую каждый администратор баз данных должен выполнять идеально, является восстановление базы данных, если она по какой-то причине окажется поврежденной. Модель восстановления (recovery model) базы данных определяет варианты, которые имеются у администратора при восстановлении базы данных. Если администратор не может восстановить базу данных в случае аварии, ему лучше стряхнуть пыль со своего резюме и начать искать новое направление работы. Продолжить чтение "Понимание моделей восстановления SQL Server"
Категории: T-SQL

Должен ли я заменить слияние строк с помощью FOR XML PATH на String_agg?

Пересказ статьи Jeffry Schwartz. Should I Replace My FOR XML PATH String Merges with String_agg?


Если вы ищете в этом, в первую очередь, прирост производительности, то ответ - нет. Однако, если вы используете SQL Server 2017 и разрабатываете новый код, вам следует рассмотреть использование новой функции String_agg, которая появилась в SQL Server 2017, поскольку код с использованием этой функции намного более читабелен, и его легче написать и поддерживать. В этой статье сравнивается производительность двух методов с объяснением разницы в коде. Представленные примеры задействуют списки имен таблиц SQL Server, которые соединяются в предложении динамического SQL, которое может быть использовано в предложениях WHERE или JOIN.


Продолжить чтение "Должен ли я заменить слияние строк с помощью FOR XML PATH на String_agg?"
Категории: T-SQL

Год 2020, так ли еще нужен DBCC CHECKDB?

Пересказ статьи Daniel Janik. It’s 2020, Do I really need to DBCC CHECKDB?


Скажем, вы получаете запрос на восстановление бэкапа базы данных в Azure Managed Instance. Вы выполняете эту задачу, а затем несколькими днями спустя команда, которая просила сделать восстановление, сообщает, что они имеют проблемы с подключением к недавно восстановленному бэкапу.


Продолжить чтение "Год 2020, так ли еще нужен DBCC CHECKDB?"
Категории: T-SQL

Новости за 2020-12-26 - 2021-01-01

§ С Новым годом! Счастья, здоровья и удачи!


§ selber и qwrqwr приложили голову к усилению проверки задачи 8 (SELECT, обуч. этап).


В ответ на замечание pooteen усилена проверка задачи 49 (SELECT, обуч. этап).

Продолжить чтение "Новости за 2020-12-26 - 2021-01-01"