Проверь свой T-SQL код!Источник: habrahabr hTLK
В далёком 2005 году я менял стек технологий с Java на .NET и поначалу в Visual Studio мне очень не хватало возможностей, которыми располагала IntelliJ IDEA. Пробуя различные плагины к студии, я остановился на ReSharper'е и по сей день его использую. Недавно стало интересно, есть ли похожие продукты для работы с SQL Server, а точнее с T-SQL кодом хранимых процедур. Собственно про один такой продукт я и хочу рассказать в этой статье. Итак, SqlCodeGuard - это бесплатный addin для SQL Server Management Studio для статического анализа T-SQL кода. Ну и плюс пара-тройка других возможностей.
Основные возможности
Поиск потенциальных ошибок в кодеНасколько я понимаю, поддерживается более сотни ситуаций различной направленности от "лучше так не делать" до "а вот тут - гарантированно свалится" и "причина тормозов - вот она".
Поиск зависимостей объектовПозволяет определить, кто и где используется (какие таблицы использует процедура/функция/представление) и решает обратную задачу - позволяет определить - кто использует тот или иной объект, причем для таблиц и представлений - как (!) используется - выборка данных/вставка/обновление/удаление.
Cписок объектов, которые не были найдены в анализируемой БДПобочная возможность. Позволяет, например, отслеживать опечатки в наименованиях таблиц, процедур и т.п. Как известно, SQL Server позволяет создать процедуру, которая использует несуществующую процедуру или таблицу или удалить объект, который используется в процедурах/представлениях. Такие ошибки проявятся только на этапе выполнения, так что нахождение их на этапе кодирования - немалый плюс.
Древовидное отображение структуры кодаПолезно для сложных процедур - позволяет быстро просмотреть/понять логику сложного кода а также оценить сложность процедуры/функции/представления в неких единицах сложности "P". Заодно подсчитывает количество стейтментов.
Преимущества продукта...
И, что представляет особый интерес для групповой разработки в больший компаниях - предоставляется специальное API, которое позволяет использовать возможности проверки кода в своих приложениях. Например, можно встроить проверку SQL кода в свой build-process или реализовать Checkin Policy.
… и его недостатки
Неплохо было бы чтобы была возможность "из коробки" использовать интеграцию с continuous integration, но пока что этого нет.
Краткое резюмеВ целом, несмотря на определённые недостатки, SqlCodeGuard вполне пригоден к применению как отдельными разработчиками, так и, вероятно, группами разработчиков для обеспечения единой политики написания кода а также для упрощения анализа существующих БД. |