Skip to content

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

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


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

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

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

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


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

Краткое руководство по запуску кода 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 и новым методам преобразования данных.
Continue reading "Краткое руководство по запуску кода 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, но возвращают процент в группе, а не просто ранговый номер.
Continue reading "Какая разница между PERCENT_RANK и CUME_DIST?"

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

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


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

Должен ли я заменить слияние строк с помощью 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.


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

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

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


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


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