SSIS Package not wanting to fetch metadata of temporary table

后端 未结 6 2087
小鲜肉
小鲜肉 2020-11-29 03:39

I have an SSIS Package, which contains multiple flows.

Each flow is responsible for creating a \"staging\" table, which gets filled up after creation. These tables a

相关标签:
6条回答
  • 2020-11-29 03:53

    Had the same issue as we use temp table for staging. After spending some time, found a work around.

    In the OLE DB/ADO Destination of Data flow task where you specify the name of the staging table .

    Change the AccessMode property to SQL command instead of OpenRowSet and specify SQL Command property to "select * from #temp".

    Hurray, Its working as expected.

    Catch here is when you specify Access mode other than SQL Command, SSIS expects that to be a table / view and it changed the SSIS to call sp_describe_first_result_set to get the meta data. but when you specify SQL Command, it's expecting a query or SP command etc. so luckily it still uses the old way of getting the meta data .

    http://social.msdn.microsoft.com/Forums/sqlserver/en-US/cfe1c7c1-910a-4f52-9718-c3406263b177/usage-of-temp-tables-in-ssis-2012?forum=sqlintegrationservices#cfe1c7c1-910a-4f52-9718-c3406263b177

    0 讨论(0)
  • 2020-11-29 03:58

    If you are working on SSIS 2012, then it uses system stored procedure sp_describe_first_result_set to fetch the metadata of the tables and it does not support temporary tables. But you can go for other options like table variables and CTEs which are going to work fine. https://connect.microsoft.com/SQLServer/feedback/details/629077/denali-engine-metadata-discovery-shuns-temp-tables

    0 讨论(0)
  • 2020-11-29 04:01

    I had faced a similar issue when SSSI packages were migrated from 2008 to 2016. The latest version uses sp_describe_first_result_set to fetch metadata and it does not work with temporary tables. As a workaround, I used the below query in the OLEDB source editor. I did not change the SQL stored procedure, and it still uses a temporary table. Do be sure to use the Parse Query and Preview option to ensure it works fine. See the image below.

    Query:

    EXEC [dbo].[spGetNames]
    WITH RESULT SETS((
            FirstName varchar(50), 
            LastName varchar(50)
    ));
    

    See Image

    0 讨论(0)
  • 2020-11-29 04:03

    Another option (kind of a hack, but it works and doesn't require you to change your use of global temp tables) is to use a SET FMTONLY ON command in front of your actual query to send a fake "First result set" to SSIS with your correct column structure. So you can do something like

    SET FMTONLY ON
    select 0 as a, 1 as b, 'test' as C, GETDATE() as D
    SET FMTONLY OFF
    
    select a, b, c, d from ##TempTable
    

    When SSIS runs sp_describe_first_result_set, it will return the metadata and column names of your FMTONLY command, and won't complain about not being able to determine the metadata of your temp table because it won't even try.

    0 讨论(0)
  • 2020-11-29 04:13

    Using WITH RESULT SETS to explicitly define the metadata will allow SSIS to skip the sp_describe_first_result_set step and use the metadata that you define. The upside is that you can use this to get SSIS to execute SQL that contains a temporary table (for me, that performance helped a lot); the downside is, you have to manually maintain and update this if anything changes.

    Query sample (stored procedure:)

        EXEC ('dbo.MyStoredProcedure')
        WITH RESULT SETS
          (
            (
                MyIntegerColumn INT NOT NULL,
                MyTextColumn VARCHAR(50) NULL,
                MyOtherColumn BIT NULL
            )
          )
    

    Query sample (simple SQL:)

    EXEC ('
        CREATE TABLE #a 
          (
            MyIntegerColumn INT NOT NULL,
            MyTextColumn VARCHAR(50) NULL,
            MyOtherColumn BIT NULL
          ) 
        INSERT INTO #a 
          (
            MyIntegerColumn,
            MyTextColumn,
            MyOtherColumn
          )
        SELECT 
            1 AS MyIntegerColumn,
            ''x'' AS MyTextColumn,
            0 AS MyOtherColumn
    
        SELECT MyIntegerColumn, MyTextColumn, MyOtherColumn
        FROM #a')
    
    WITH RESULT SETS
        (
            (
                MyIntegerColumn INT NOT NULL
               ,MyTextColumn VARCHAR(50) NULL
               ,MyOtherColumn BIT NULL
            )
        )
    
    0 讨论(0)
  • 2020-11-29 04:13

    I found that the problem lied in a GUID duplicate issue, I copied elements (like the one to create temp tables) and they all received the same guid upon copying. I used a tool to reset all these guids in my package and this solved my problem.

    Thanks!

    0 讨论(0)
提交回复
热议问题