Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2006.04.09;
Скачать: CL | DM;

Вниз

Построение иерархии зависимостей объектов БД   Найти похожие ветки 

 
Ольга   (2006-02-14 18:00) [0]

Если в Enterprize Manager выбрать объект -> Все задачи -> Display Dependencies, можно получить два набора данных - список объектов, от которых зависит данный объект и список объектов, которые зависят от данного объекта.
Написала функцию, которая делает то же самое (только для первого уровня зависимости). Хочу теперь с помощью этой функции создать временную таблицу зависимостей объектов БД от самых независимых до самых зависимых, пронумеровать их.
Завязла в рекурсиях, ничего не получается... все циклит.
Может кто подскажет алгоритм создания такой таблицы?

Текст функции:

CREATE FUNCTION dbo.GetDependObj
(@name varchar(50),   -- имя ибъекта БД
@type_depend int)      -- тип зависимости
RETURNS @Data TABLE
(name varchar(50), xtype varchar(20))
AS
BEGIN

 DECLARE @id int
 SELECT @id=id FROM sysobjects WHERE name=@name

 IF @type_depend=1  -- объекты, от которых зависит @name
 BEGIN
   INSERT INTO @Data
   SELECT DISTINCT a.name, a.xtype
   FROM sysobjects a, sysdepends b
   WHERE b.id=@id and a.id=b.depid
   UNION
   SELECT DISTINCT a.name, a.xtype
   FROM sysobjects a, sysforeignkeys b
   WHERE b.fkeyid=@id and a.id=b.rkeyid
 END

 IF @type_depend=2  -- объекты, зависимые от @name
 BEGIN
   INSERT INTO @Data
   SELECT DISTINCT a.name, a.xtype
   FROM sysobjects a, sysdepends b
   WHERE b.depid=@id and a.id=b.id
 END
 RETURN
 
END


 
Nikolay M. ©   (2006-02-14 18:16) [1]

sp_MSdependencies
?

http://www.sql.ru/articles/mssql/02030101UndocumentedSQL.shtml#sp_MSdependencies


 
Ольга   (2006-02-14 18:24) [2]

Вот спасибо! Целый день убила... Оказывается это колесо уже давно изобрели! Еще раз спасибо - то что надо.


 
Nikolay M. ©   (2006-02-14 18:41) [3]

Не за что.
В принципе, эта ХП легко обнаруживается профайлером, если в ЕМ сделать тот самый просмотр зависимостей.



Страницы: 1 вся ветка

Текущий архив: 2006.04.09;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.046 c
3-1140073857
Scorpio
2006-02-16 10:10
2006.04.09
Пароль на БД Paradox 7


3-1140019073
Ольга
2006-02-15 18:57
2006.04.09
Странное сообщение SQL-сервера


1-1141316179
Игорь Степанов
2006-03-02 19:16
2006.04.09
Программное перемещение курсора мыши по ячейкам StringGrid


9-1126292049
Ford
2005-09-09 22:54
2006.04.09
RPG


4-1137610292
Volf_555
2006-01-18 21:51
2006.04.09
Как в TPopup добавить путь к программе с её иконкой?