Получить имя схемы для зависимых объектов с помощью SMO - PullRequest
0 голосов
/ 11 января 2011

Используя компонент исходного скрипта в SSIS, я пытаюсь получить подробную информацию обо всех объектах, которые зависят от таблицы. Пока у меня есть тип объекта и имя, но я не могу получить схему. Кто-нибудь знает, как добиться этого в SMO?

Мой код компонента скрипта:

' Microsoft SQL Server Integration Services user script component
' This is your new script component in Microsoft Visual Basic .NET
' ScriptMain is the entrypoint class for script components

Imports System
Imports System.Data
Imports System.Math
Imports Microsoft.SqlServer.Dts.Pipeline.Wrapper
Imports Microsoft.SqlServer.Dts.Runtime.Wrapper
Imports Microsoft.SqlServer.Management.Smo
Imports Microsoft.SqlServer.Management.Common

Public Class ScriptMain
    Inherits UserComponent

    Public Overrides Sub CreateNewOutputRows()
        '
        '
        '
        Dim TargetSQLServer As Server
        Dim TargetDatabase As Database
        Dim TargetTable As Table
        Dim uc As New UrnCollection()
        Dim dw As New DependencyWalker
        Dim dt As DependencyTree
        Dim dc As DependencyCollection
        Dim dcn As DependencyCollectionNode
        Dim sp As New Scripter
        Dim outputString As String

        TargetSQLServer = New Server("localhost")
        TargetDatabase = TargetSQLServer.Databases("AdventureWorks")


        For Each TargetTable In TargetDatabase.Tables
            ' Exclude these objects 
            If TargetTable.IsSystemObject = False Then
                uc = New UrnCollection()
                uc.Add(TargetTable.Urn)
                sp = New Scripter
                sp.Server = TargetSQLServer

                ' Get dependencies 
                dw = New DependencyWalker
                dw.Server = TargetSQLServer
                dt = dw.DiscoverDependencies(uc, DependencyType.Children)
                sp = New Scripter(TargetSQLServer)

                dc = New DependencyCollection
                dc = sp.WalkDependencies(dt)
                outputString = ""
                For Each dcn In dc
                    Me.Output0Buffer.AddRow()
                    Me.Output0Buffer.Database = TargetDatabase.Name.ToString

                    Me.Output0Buffer.Table = TargetTable.Name.ToString

                    outputString = dcn.Urn.ToString
                    Me.Output0Buffer.Dependency.AddBlobData(Text.Encoding.GetEncoding(1252).GetBytes(outputString))

                    Me.Output0Buffer.ObjectType = dcn.Urn.Type.ToString

                    outputString = dcn.Urn.GetNameForType(dcn.Urn.Type.ToString).ToString
                    Me.Output0Buffer.ObjectName.AddBlobData(Text.Encoding.GetEncoding(1252).GetBytes(outputString))

                    outputString = ""
                    Me.Output0Buffer.Schema.AddBlobData(Text.Encoding.GetEncoding(1252).GetBytes(outputString))
                Next
            End If
        Next

    End Sub

End Class

1 Ответ

0 голосов
/ 01 февраля 2011

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

Ваша урна будет возвращена в форме

///StoredProcedure[@Name='uspUpdateEmployeeHireInfo' and @Schema='HumanResources']

Просто выполните анализ @Name, а затем @ Schema.

Загрузите исходный код для DBSourceTools: http://dbsourcetools.codeplex.comПосмотрите DBSourceToolsLib.SysObjects.UrnParser, а также DBSourceToolsLib.SysObjects.SODependencyTree для рабочих примеров.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...