+7 (495) 229-0436   shopadmin@itshop.ru 119334, г. Москва, ул. Бардина, д. 4, корп. 3
 
 
Вход
 
 
Каталог
 
 
Подписка на новости
Новости ITShop
Windows 7 и Office: Новости и советы
Обучение и сертификация Microsoft
Вопросы и ответы по MSSQLServer
Delphi - проблемы и решения
Adobe Photoshop: алхимия дизайна
 
Ваш отзыв
Оцените качество магазина ITShop.ru на Яндекс.Маркете. Если вам нравится наш магазин - скажите об этом Google!
 
 
Способы оплаты
 
Курс расчета
 
 1 у.е. = 92.51 руб.
 
 Цены показывать:
 
 
 
 
  
Новости, статьи, акции
 

Улучшаем Redgate SQL Search: некоторые моменты разработки

02.08.2012 14:39
yar229

Трепетно люблю и пользую при работе в SQL Server Management Studio утилиты от Redgate, в том числе и бесплатный Redgate SQL Search
Все бы хорошо, но еще мечталось о вменяемом инструменте, который бы позволял в дереве объектов создавать собственные папки и раскладывать в них таблички/процедурки.
В один прекрасный момент таковой появился - SQLTreeO, но тут же наткнулся на проблему - SQLSearch не ищет в созданных им папках.

Собственно, с этого и начался маленький addin для addin'а -SQLSearch Extender. Дальше - больше, раз пошла такая пьянка, то почему бы не добавить по мере сил функционала, так как Redgate не торопится реализовывать пожелания пользователей.
Что добавлено к функционалу SQLSearch'а (настройки в меню Tools -> SQL Search Extender):

  • Поиск в папках, созданных SQLTreeO
  • Regexp поиск
  • Подсветка кода и нумерация строк, навигация по вхождениям
  • Показывает скрипты таблиц и CLR UDF
  • Фильтр для исключения из поиска по имени объектов (например, sp_MS%, %__temp, etc.)
  • … всяческие дополнительные фишки

Собственно, заметки по разработке.
API для SSMS Microsoft не афиширует, на старте очень помогли следующие статьи - 
The Black Art of Writing a SQL Server Management Studio 2005 Add In и SQL 2008r2 breaks ssms addins

Практически все, что надо для счастья, в этих статьях рассказано, отмечу несколько моментов

Момент 1. Ловим окно SQLSearch.


Так как информации изначально у нас практически нет, то вешаем обработчик на Connect.OnCmdUIContextChanged и вспоминаем WinAPI EnumChildWindows. С глубоким внутренним удовлетворением обнаруживаем, что внутре нужного окна лежит наследник от UserControl, далее по типу и имени (Hawkeye в помощь) находим нужные нам элементы. Дальше делаем с интерфейсом все, что нам угодно.

Момент 2. Поиск в папках SQLTreeO


Идея проста - после того, как отработает поиск SQLSearch'а, смотрим на выделенный в Object Explorer'е элемент и, если его имя не совпадает с нужным, то поднимаемся до уровня узла сервера и пробегаемся по папкам.

Момент 3. Подсветка синтаксиса.


Скрипты SQLSearch выводит в стандартный RichEdit. Очень хотелось накрыть его сверху редактором от самой студии (случайная ссылка для ключевых слов), практически получилось, но не хватило терпения расследовать и устранять всяческие мелкие неурядицы. 
В итоге пошел по пути наименьшего сопротивления, спрятав его за своим RichEdit'ом и вспомнив о существовании Microsoft.SqlServer.SqlParser.Parser и, для скорости, формируя RTF ручками.

Момент 4. Хочу красивую иконку в меню Tools!


Как это ни смешно, но если в выпадающих контекстных меню это делается без проблем, то в данном случае информации не нашел, пришлось повозиться - обратиться к System.Windows.Forms.AxHost, IPictureDisp и колдовать с масками.

Момент 5. Хочу поиск regexp'ами!


Поначалу опечалился, так как не видел способа сделать это без модификации самого SQLSearch'а, но потом нашлось решение. 
SQLSearch для кэширования данных использует SQLite и .NET обертку для него System.Data.SQLite, загрузка библиотеки фактически происходит в момент, когда мы начинаем поиск. Но так как мы находимся в одном домене и отлавливаем окно еще до начала поиска, то можем быстренько загрузить свою библиотеку SQLite. Скачиваем исходники System.Data.SQLite, убеждаемся в соответствии номера версии и ключа тому, что использует сам SQLSearch, и модифицируем System.Data.SQLite.SQLiteCommand, отлавливая sql запросы и изменяя нужные.
Реализация самого поиска regexp'ами оказалась проста - достаточно в своей библиотеке реализовать класс, пометив его атрибутом SQLiteFunction - SQLite REGEXP function, после чего можем писать всякие штуки вроде select * from table where text REGEXP '.*GOOD\Z'

Этот же хак помог снять ограничение на максимальное количество результатов поиска - SQLSearch ограничивает выдачу 150 результатами.

Момент 6. Получение скриптов объектов.


Все просто - выручает Microsoft.SqlServer.Management.Smo

В планах, just4fun, хочется декомпилировать и показывать исходники CLR UDF, используя родственный .NET Reflector, но пока с этим проблемы, связанные с тем, что 

  • сам addin должен использовать версию .NET Framework не старше, чем 3.5 (требование SSMS), а .NET Reflector нонеча под 4.0. (обходим через COM...)
  • нельзя из .NET вызывать COM объект, писанный под .NET-ом (обходится...)
  • и после того, как все это было побеждено и работало в тестовой версии, при запуске из SSMS падает с COM error 8004003.

Писалось под MS Visual Studio 2010, .NET framework 3.5 и тестировалось под Microsoft SQL Server Management Studio 10.0.1600.22 (SQL Server 2008R2)

Сами исходники пока не выкладываю, но библиотечка ничем не закрыта, объем кода небольшой и, при наличии рефлектора, любой желающий реализацию может посмотреть.

Ссылки:


Скачать 
Страничка SQLSearchExtender на лицокнига
"Обсуждение" на форуме SQLTreeO

Upd 2012.06.27
Исправлено падение под SSMS v.10.50.*

А пока суть да дело, на сайте Redgate'а обновился SQLSearch с версии 1.1.4.3 до 1.1.6.1 и [FIXED] хак с подменой SQLite на лету теперь не работает.
Помогает копирование x:\Program Files (x86)\SQLSearch2SQLTreeO\SQLite.Interop.dll и x:\Program Files (x86)\SQLSearch2SQLTreeO\System.Data.SQLite.dll в "x:\ProgramData\Red Gate\SQL Search\Active" и "x:\ProgramData\Red Gate\SQL Search\Source". Вот такая незадачка, буду разбираться.

Ссылки по теме

  
Помощь
Задать вопрос
 программы
 обучение
 экзамены
 компьютеры
Бесплатный звонок
ICQ-консультанты
Skype-консультанты

Общая справка
Как оформить заказ
Тарифы доставки
Способы оплаты
Прайс-лист
Карта сайта
 
Бестселлеры
Курсы обучения "Atlassian JIRA - система управления проектами и задачами на предприятии"
Microsoft Windows 10 Профессиональная 32-bit/64-bit. Все языки. Электронный ключ
Microsoft Office для Дома и Учебы 2019. Все языки. Электронный ключ
Курс "Oracle. Программирование на SQL и PL/SQL"
Курс "Основы TOGAF® 9"
Microsoft Office 365 Персональный 32-bit/x64. 1 ПК/MAC + 1 Планшет + 1 Телефон. Все языки. Подписка на 1 год. Электронный ключ
Курс "Нотация BPMN 2.0. Ее использование для моделирования бизнес-процессов и их регламентации"
 

О нас
Интернет-магазин ITShop.ru предлагает широкий спектр услуг информационных технологий и ПО.

На протяжении многих лет интернет-магазин предлагает товары и услуги, ориентированные на бизнес-пользователей и специалистов по информационным технологиям.

Хорошие отзывы постоянных клиентов и высокий уровень специалистов позволяет получить наивысший результат при совместной работе.

В нашем магазине вы можете приобрести лицензионное ПО выбрав необходимое из широкого спектра и ассортимента по самым доступным ценам. Наши менеджеры любезно помогут определиться с выбором ПО, которое необходимо именно вам. Также мы проводим учебные курсы. Мы приглашаем к сотрудничеству учебные центры, организаторов семинаров и бизнес-тренингов, преподавателей. Сфера сотрудничества - продвижение бизнес-тренингов и курсов обучения по информационным технологиям.



 

О нас

 
Главная
Каталог
Новинки
Акции
Вакансии
 

Помощь

 
Общая справка
Как оформить заказ
Тарифы доставки
Способы оплаты
Прайс-лист
Карта сайта
 

Способы оплаты

 

Проекты Interface Ltd.

 
Interface.ru   ITShop.ru   Interface.ru/training   Olap.ru   ITnews.ru  
 

119334, г. Москва, ул. Бардина, д. 4, корп. 3
+7 (495) 229-0436   shopadmin@itshop.ru
Проверить аттестат
© ООО "Interface Ltd."
Продаем программное обеспечение с 1990 года