(495) 925-0049, ITShop интернет-магазин 229-0436, Учебный Центр 925-0049
  Главная страница Карта сайта Контакты
Поиск
Вход
Регистрация
Рассылки сайта
 
 
 
 
 

Отлов несовместностей после перехода на SQL Server 2008. Часть 2

В предыдущем посте для определения deprecated функциональности приложения использовались счетчики Performance Monitor категории SQL Server:Deprecated Features и DMV sys.dm_os_performance_counters (sys.sysperfinfo). Все хорошо за исключением того, что они ловят все в масштабах сервера, а хотелось бы ограничить масштаб проверки проверяемым приложением или хотя бы конкретной БД. Счетчики только сигнализируют, что такая-то deprecated фича только что встретилась, а в каком месте скрипта - неизвестно. При больших объемах кода лопатить все как-то накладно. Эти неудобства позволяет преодолеть второй способ, который использует профайлер. В профайлере у нас есть два замечательных события в категории Deprecation. Они называются Deprecation Announcement event class и Deprecation Final Support event class. Откройте скорее профайлер и отметьте оба этих замечательных события.

image

рис.1

Отметьте к ним за компанию также события в категории Stored Procedures RPC:Completed, SP:Completed, SP:StmtCompleted и в категории T-SQL SQL:BatchCompleted. Остальные события, которые были по дефолту отмечены, если вы использовали какой-либо шаблон трассы, разотметьте дабы не зашумлять картину. Пойдите в Column Filters и выберите какие хотите ограничения на ApplicationName, DatabaseName и пр.

image

рис.2

Запустите трассу. Перейдите в SSMS и начните прогонять несовместный скрипт из поста SQL Server 2008 Upgrade Advisor (Скрипт 1, часть 2):

select databaseproperty('AdventureWorks_2005', 'Version') --будет заменена на  databasepropertyex

exec sp_dboption @dbname = 'AdventureWorks_2005', @optname = 'trunc. log on chkpt.', @optvalue = 'true' --sp_dboption в целом заменяется командой alter database; в данном случае действие эквивалентно ALTER DATABASE ... SET RECOVERY SIMPLE

select * from Production.Product with (fastfirstrow) -- хинт заменен на OPTION (FAST N)

select * from Production.Product order by Name collate SQL_AltDiction_CP1253_CS_AS

select * from Production.Product p, Production.ProductSubcategory sc, Production.ProductCategory c

 where p.ProductSubcategoryID *= sc.ProductSubcategoryID and sc.ProductCategoryID *= c.ProductCategoryID -- заменен на синтаксис ANSI left/right outer join

declare @t table (fld1 text, fld2 image) --замена на varchar/varbinary(max)

declare @db_id int, @tbl_id int; select @db_id = db_id(), @tbl_id = object_id('Production.Product'); dbcc pintable(@db_id, @tbl_id)

Скрипт 1

Вернитесь в профайлер и посмотрите результат.

image

рис.3

Как и в случае Perfmon, все несовместности благополучно поймались, однако теперь вместе с ругательством можно наблюдать конкретный кусок кода, где она проявилась и куда, соотвественно, нужно лезть, чтобы ее поправить.

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


 Распечатать »
 Правила публикации »
  Написать редактору 
 Рекомендовать » Дата публикации: 24.03.2010 
 

Магазин программного обеспечения   WWW.ITSHOP.RU
Microsoft Office 365 Бизнес. Подписка на 1 рабочее место на 1 год
Microsoft Office 365 Профессиональный Плюс. Подписка на 1 рабочее место на 1 год
Microsoft 365 Business Basic (corporate)
Microsoft Windows Professional 10, Электронный ключ
Microsoft 365 Apps for business (corporate)
 
Другие предложения...
 
Курсы обучения   WWW.ITSHOP.RU
 
Другие предложения...
 
Магазин сертификационных экзаменов   WWW.ITSHOP.RU
 
Другие предложения...
 
3D Принтеры | 3D Печать   WWW.ITSHOP.RU
 
Другие предложения...
 
Новости по теме
 
Рассылки Subscribe.ru
Информационные технологии: CASE, RAD, ERP, OLAP
Безопасность компьютерных сетей и защита информации
Новости ITShop.ru - ПО, книги, документация, курсы обучения
Программирование на Microsoft Access
CASE-технологии
Corel DRAW - от идеи до реализации
Windows и Office: новости и советы
 
Статьи по теме
 
Новинки каталога Download
 
Исходники
 
Документация
 
 



    
rambler's top100 Rambler's Top100