sql - स्वचालित रूप से संस्करण संख्या पुनर्प्राप्ति से डीटीएसएक्स फ़ाइलें




sql-server ssis etl ssis-2012 (4)

क्या कोई तरीका है या क्वेरी जिसके द्वारा मैं SSIS पैकेज (* .dtsx फ़ाइलें) की संस्करण संख्या पा सकता हूं?

मेरी टीम फाउंडेशन सर्वर में *.dtsx फाइलें हैं, जिसके लिए मुझे जानना था।

मैन्युअल तरीके से एक माउस को पैकेज पर राइट-क्लिक करना है और VersionBuild देखने के लिए Compare करें पर क्लिक Compare , लेकिन हजारों संकुल की तरह हैं, मैन्युअल रूप से ऐसा करने से वास्तव में संभव नहीं है

नोट: इस प्रक्रिया को स्वचालित होना चाहिए, मैन्युअल नहीं


Answers

डीटीएसएक्स पैकेज में मूल्य प्राप्त करना

  • यदि आप इस पैकेज के भीतर एक पैकेज संस्करण पढ़ने की कोशिश कर रहे हैं तो आप SSIS सिस्टम चर में से एक तक पहुंच सकते हैं

    Variable        Type    Description
    -------------------------------------------
    VersionBuild    Int32   The package version.
    VersionComment  String  Comments about the package version.
    VersionGUID     String  The unique identifier of the version.
    VersionMajor    Int32   The major version of the package.
    VersionMinor    Int32   The minor version of the package.
  • यदि आप पैकेज एसक्यूएल सर्वर संस्करण की तलाश कर रहे हैं, तो आप इसे dtsx फ़ाइल के अंदर पा सकते हैं यदि आप इसे टेक्स्ट (या एक्सएमएल) के रूप में खोलते हैं और PackageFormatVersion प्रॉपर्टी की खोज करते हैं, विस्तृत जानकारी निम्न लिंक में उपलब्ध कराई जाती हैं:

एसटीएल सर्वर में डाले गए .dtsx फ़ाइलों से मूल्य प्राप्त करना

आप इन लिंक का अनुसरण कर सकते हैं:

इसमें इस मुद्दे को प्राप्त करने वाले प्रश्न शामिल हैं

Sql सर्वर में संग्रहीत नहीं .dtsx फ़ाइलों से मूल्य प्राप्त करना

PackageFormatVersion को पढ़ने के लिए स्वचालित PackageFormatVersion आप प्रोग्राम को एक XMLParser या Regex का उपयोग करके इसे पढ़ सकते हैं। मैंने .dtsx में एक कोड लिखा था जो एक निर्देशिका के अंदर। .dtsx फाइलों पर Regex और लूप का उपयोग करता है और .dtsx PackageFormatVersion और डीटीएसएक्स फ़ाइल हेडर में मिली अन्य गुण प्राप्त करता है:

  • PackageFileName
  • PackageFormatVersion
  • रचना तिथि
  • CreationName
  • CreatorComputerName
  • CreatorName
  • DTSID
  • ExecutableType
  • LastModifiedProductVersion
  • LocaleID
  • ObjectName
  • बंडल का प्रकार
  • VersionBuild
  • VersionGUID

सबसे पहले मैंने ऊपर सूचीबद्ध सूची में PackageInfo नामक क्लास बनाया है

Public Class PackageInfo

    Public Property PackageFileName As String
    Public Property PackageFormatVersion As String
    Public Property CreationDate As String
    Public Property CreationName As String
    Public Property CreatorComputerName As String
    Public Property CreatorName As String
    Public Property DTSID As String
    Public Property ExecutableType As String
    Public Property LastModifiedProductVersion As String
    Public Property LocaleID As String
    Public Property ObjectName As String
    Public Property PackageType As String
    Public Property VersionBuild As String
    Public Property VersionGUID As String


End Class

RegEx का उपयोग करना

Private Sub ReadPackagesInfo(ByVal strDirectory As String)


        m_lst.Clear()

        For Each strFile As String In IO.Directory.GetFiles(strDirectory, "*.dtsx", IO.SearchOption.AllDirectories)


            Dim strContent As String = ""

            Using sr As New IO.StreamReader(strFile)

                strContent = sr.ReadToEnd
                sr.Close()

            End Using


            Dim strPackageFormatVersion As String = Regex.Match(strContent, "(?<=""PackageFormatVersion"">)(.*)(?=</DTS:Property>)", RegexOptions.Singleline).Value
            Dim strCreationDate As String = Regex.Match(strContent, "(?<=DTS:CreationDate="")(.*?)(?="")", RegexOptions.Singleline).Value
            Dim strCreationName As String = Regex.Match(strContent, "(?<=DTS:CreationName="")(.*?)(?="")", RegexOptions.Singleline).Value
            Dim strCreatorComputerName As String = Regex.Match(strContent, "(?<=DTS:CreatorComputerName="")(.*?)(?="")", RegexOptions.Singleline).Value
            Dim strCreatorName As String = Regex.Match(strContent, "(?<=DTS:CreatorName="")(.*?)(?="")", RegexOptions.Singleline).Value
            Dim strDTSID As String = Regex.Match(strContent, "(?<=DTS:DTSID="")(.*?)(?="")", RegexOptions.Singleline).Value
            Dim strExecutableType As String = Regex.Match(strContent, "(?<=DTS:ExecutableType="")(.*?)(?="")", RegexOptions.Singleline).Value
            Dim strLastModifiedProductVersion As String = Regex.Match(strContent, "(?<=DTS:LastModifiedProductVersion="")(.*?)(?="")", RegexOptions.Singleline).Value
            Dim strLocaleID As String = Regex.Match(strContent, "(?<=DTS:LocaleID="")(.*?)(?="")", RegexOptions.Singleline).Value
            Dim strObjectName As String = Regex.Match(strContent, "(?<=DTS:ObjectName="")(.*?)(?="")", RegexOptions.Singleline).Value
            Dim strPackageType As String = Regex.Match(strContent, "(?<=DTS:PackageType="")(.*?)(?="")", RegexOptions.Singleline).Value
            Dim strVersionBuild As String = Regex.Match(strContent, "(?<=DTS:VersionBuild="")(.*?)(?="")", RegexOptions.Singleline).Value
            Dim strVersionGUID As String = Regex.Match(strContent, "(?<=DTS:VersionGUID="")(.*?)(?="")", RegexOptions.Singleline).Value



            m_lst.Add(New PackageInfo With {.PackageFileName = strFile,
                      .PackageFormatVersion = strPackageFormatVersion,
                      .CreationDate = strCreationDate,
                      .CreationName = strCreationName,
                      .CreatorComputerName = strCreatorComputerName,
                      .CreatorName = strCreatorName,
                      .DTSID = strDTSID,
                      .ExecutableType = strExecutableType,
                      .LastModifiedProductVersion = strLastModifiedProductVersion,
                      .LocaleID = strLocaleID,
                      .ObjectName = strObjectName,
                      .PackageType = strPackageType,
                      .VersionBuild = strVersionBuild,
                     .VersionGUID = strVersionGUID})


        Next



End Sub

कोड की निम्न पंक्ति वह है जो फ़ाइल से PackageFormatVersion प्रॉपर्टी PackageFormatVersion है

Dim strA As String = Regex.Match(strContent, "(?<=""PackageFormatVersion"">)(.*)(?=</DTS:Property>)", RegexOptions.Singleline).Value

XML पार्सर का उपयोग करना

    Private Sub ReadPackagesInfoUsingXmlParser(ByVal strDirectory As String)

        m_lst.Clear()

        For Each strFile As String In IO.Directory.GetFiles(strDirectory, "*.dtsx", IO.SearchOption.AllDirectories)

            Dim strPackageFormatVersion As String = ""
            Dim strCreationDate As String = ""
            Dim strCreationName As String = ""
            Dim strCreatorComputerName As String = ""
            Dim strCreatorName As String = ""
            Dim strDTSID As String = ""
            Dim strExecutableType As String = ""
            Dim strLastModifiedProductVersion As String = ""
            Dim strLocaleID As String = ""
            Dim strObjectName As String = ""
            Dim strPackageType As String = ""
            Dim strVersionBuild As String = ""
            Dim strVersionGUID As String = ""


            Dim xml = XDocument.Load(strFile)

            Dim ns As XNamespace = "www.microsoft.com/SqlServer/Dts"
            Dim man As XmlNamespaceManager = New XmlNamespaceManager(New NameTable())
            man.AddNamespace("DTS", "www.microsoft.com/SqlServer/Dts")

            If Not xml.Root Is Nothing AndAlso
                Not xml.Root.Descendants(ns + "Property").Attributes(ns + "Name") Is Nothing AndAlso
                     xml.Root.Descendants(ns + "Property").Attributes(ns + "Name").Where(Function(x) x.Value = "PackageFormatVersion").Count > 0 Then

                strPackageFormatVersion = xml.Root.Descendants(ns + "Property").Attributes(ns + "Name").Where(Function(x) x.Value = "PackageFormatVersion").FirstOrDefault.Parent.Value

                strCreationDate = If(xml.Root.Attributes(ns + "CreationDate").FirstOrDefault Is Nothing, "", xml.Root.Attributes(ns + "CreationDate").FirstOrDefault.Value)
                strCreationName = If(xml.Root.Attributes(ns + "CreationName").FirstOrDefault Is Nothing, "", xml.Root.Attributes(ns + "CreationName").FirstOrDefault.Value)
                strCreatorComputerName = If(xml.Root.Attributes(ns + "CreatorComputerName").FirstOrDefault Is Nothing, "", xml.Root.Attributes(ns + "CreatorComputerName").FirstOrDefault.Value)
                strCreatorName = If(xml.Root.Attributes(ns + "CreatorName").FirstOrDefault Is Nothing, "", xml.Root.Attributes(ns + "CreatorName").FirstOrDefault.Value)
                strDTSID = If(xml.Root.Attributes(ns + "DTSID").FirstOrDefault Is Nothing, "", xml.Root.Attributes(ns + "DTSID").FirstOrDefault.Value)
                strExecutableType = If(xml.Root.Attributes(ns + "ExecutableType").FirstOrDefault Is Nothing, "", xml.Root.Attributes(ns + "ExecutableType").FirstOrDefault.Value)
                strLastModifiedProductVersion = If(xml.Root.Attributes(ns + "LastModifiedProductVersion").FirstOrDefault Is Nothing, "", xml.Root.Attributes(ns + "LastModifiedProductVersion").FirstOrDefault.Value)
                strLocaleID = If(xml.Root.Attributes(ns + "LocaleID").FirstOrDefault Is Nothing, "", xml.Root.Attributes(ns + "LocaleID").FirstOrDefault.Value)
                strObjectName = If(xml.Root.Attributes(ns + "ObjectName").FirstOrDefault Is Nothing, "", xml.Root.Attributes(ns + "ObjectName").FirstOrDefault.Value)
                strPackageType = If(xml.Root.Attributes(ns + "PackageType").FirstOrDefault Is Nothing, "", xml.Root.Attributes(ns + "PackageType").FirstOrDefault.Value)
                strVersionBuild = If(xml.Root.Attributes(ns + "VersionBuild").FirstOrDefault Is Nothing, "", xml.Root.Attributes(ns + "VersionBuild").FirstOrDefault.Value)
                strVersionGUID = If(xml.Root.Attributes(ns + "VersionGUID").FirstOrDefault Is Nothing, "", xml.Root.Attributes(ns + "VersionGUID").FirstOrDefault.Value)
            End If



            m_lst.Add(New PackageInfo With {.PackageFileName = strFile,
                      .PackageFormatVersion = strPackageFormatVersion,
                      .CreationDate = strCreationDate,
                      .CreationName = strCreationName,
                      .CreatorComputerName = strCreatorComputerName,
                      .CreatorName = strCreatorName,
                      .DTSID = strDTSID,
                      .ExecutableType = strExecutableType,
                      .LastModifiedProductVersion = strLastModifiedProductVersion,
                      .LocaleID = strLocaleID,
                      .ObjectName = strObjectName,
                      .PackageType = strPackageType,
                      .VersionBuild = strVersionBuild,
                     .VersionGUID = strVersionGUID})

        Next

    End Sub

डेमो ऐप

इस प्रक्रिया को प्राप्त करने के लिए मैंने एक डेमो एप्लिकेशन बनाया है जिसे आप इसे निम्न लिंक से डाउनलोड कर सकते हैं:

इसके अलावा मैंने इस डेमो ऐप के लिए एक नया गीट-रिपॉजिटरी बनाई

ऐप स्क्रीनशॉट

.dtsx फ़ाइलों से मूल्य प्राप्त करना TSQL का उपयोग करना

आप अपना जवाब डीबीए पर पढ़ सकते हैं। StackExchange:

पैकेजफ़ॉर्मेट संस्करण तालिका

और यहां PackageFormatVersion तालिका मूल्य है

SQL Version Build # PackageFormatVersion    Visual Studio Version
2005        9       2                       2005
2008        10      3                       2008
2008 R2     10.5    3                       2008
2012        11      6                       2010 or BI 2012
2014        12      8                       2012 CTP2 or 2013
2016        13      8                       2015

.ispac फ़ाइल वास्तव में ज़िप फ़ाइल है और प्रत्येक .dtsx XML फ़ाइल है जिसमें सभी आवश्यक जानकारी है। इसके अतिरिक्त उत्तर देने के लिए कि दोस्तों को भेजा गया है, एक्सएमएल स्वयं सभी जानकारी रखता है जो आप चाहते हैं।

मैं आशा करता हूं कि इससे तुम्हें सहायता मिलेगी :)


यदि आप प्रोजेक्ट परिनियोजन समाधान का उपयोग करते हैं तो आप इस क्वेरी का उपयोग कर सकते हैं (यदि आपके पास SSISDB आपके सर्वर में है):

SELECT 
   [name],
   [package_format_version]
FROM [SSISDB].[catalog].[packages];

नोट: एकता सेवाओं को स्थापित किया जाना चाहिए


यदि आप 0 का उपयोग कर रहे हैं और एक खाली स्ट्रिंग '' और null को नामित करने के लिए null है, तो आपको डेटा समस्या मिल गई है। बस कॉलम अपडेट करें और अपना स्कीमा ठीक करें।

UPDATE pt.incentive_channel
SET   pt.incentive_marketing = NULL
WHERE pt.incentive_marketing = '';

UPDATE pt.incentive_channel
SET   pt.incentive_advertising = NULL
WHERE pt.incentive_marketing = '';

UPDATE pt.incentive_channel
SET   pt.incentive_channel = NULL
WHERE pt.incentive_marketing = '';

इससे जुड़ने और आगे बढ़ने में काफी आसानी होगी।







sql sql-server ssis etl ssis-2012