SSIS错误:Source的外部列与数据源列不同步;如何删除外部列?

时间:2014-06-19 18:07:38

标签: sql sql-server tsql ssis

查询应输出特定的项目列表,以及商店信息和经理信息等信息。使用Cursor翻转各种不同级别的管理列表,选择相关信息,然后通过电子邮件向该人发送查询返回的区域/区域/商店。

我的问题在于SSIS的旅程。虽然代码就像它运行一样,如果我单独运行Itemdata.dtsx(以便查看错误),它会抛出错误:

"警告:组件" Sources-ItemData"(1)的外部列与数据源列不同步。需要从外部列中删除外部列" RM_Email"(49)。需要从外部列中删除外部列" SM_Email"(46)。需要从外部列中删除外部列" DM_Email"(43)。"

这导致SQL Server Mngt Studio说它运行了,但电子邮件'内容只是表头;没有数据,表头不会改变,无论我做什么。

我已经在源代码(下面发布)和它使用的表中提及了这些列。我错过了什么?

BEGIN

SET NOCOUNT ON;

DECLARE @ProcedureName     varchar(255)
DECLARE @ExportFolder      varchar(255)
DECLARE @TempFolder        varchar(255)
DECLARE @WarningLevel      varchar(255) = 'log'
DECLARE @MsgDescription    varchar(2000) = ''
DECLARE @RecordCount       int = 0  
DECLARE @ReportDate        date = getdate()
DECLARE @Begdate           date = convert(date,(dateadd(month,-1,getdate())))
DECLARE @Enddate           date = convert(date,(dateadd(day,-1,getdate())))
DECLARE @Siteid            int 
DECLARE @Subject           varchar(75) = ''
DECLARE @Body              varchar(50) = ''
DECLARE @RMLastName        varchar(25)
DECLARE @RMFirstName           varchar(25)
DECLARE @RegionKey         int
DECLARE @DistrictKey       int
DECLARE @Email             varchar(50)

BEGIN TRY 
            --Table used as data source for each pass
            Truncate Table Example.dbo.itemdata


--Send reports to Regional Managers by building Cursor RMListCursor, 
--then running SELECT statement against each name (using @RMLastName and @RMFirstName to discern), 
--then emails results of SELECT statement to that Regional Manager. 
--Goes through CursorList, then ends. 
BEGIN
    --Set cursor for RM Email; returns all regional managers. 
DECLARE RMListCursor CURSOR FOR 
SELECT distinct t.lastname, t.firstname, t.Email
FROM Example.[dbo].[tblUser] t
JOIN example.dbo.vStoreDistrictRegionActive vs
    ON t.LastName = vs.RMLastName and t.FirstName = vs.RMFirstName 
ORDER BY LastName

OPEN RMListCursor

FETCH NEXT FROM RMListCursor
INTO @RMLastName
    , @RMFirstName
    , @Email

WHILE @@FETCH_STATUS = 0--(@SetInt < 6)

    BEGIN

    Truncate table Example.dbo.itemdata
    --Builds data, then inserts into Table built for this query. Note that there is no mention of DM_EMAIL, RM_EMAIL, or SM_EMail anywhere. 
    INSERT INTO Example.dbo.itemdata
        SELECT InvoiceNumber,
        shipFROMid,
        ad.SiteId,
        MfrCode,
        PartCode,
        UnitNetCore,
        ad.QuantityShipped,
        ShipDate,
        --First/Last Name of this item's store's District Manager. 
        rtrim(substring((SELECT ISNULL(DMfirstName,'') FROM example.dbo.vSiteRegionDistrictActiveV2 dm WHERE ad.siteid = dm.SiteNumber),1,30)) + ' ' +
            substring((SELECT ISNULL(DMLastName,'')  FROM example.dbo.vSiteRegionDistrictActiveV2 dm WHERE ad.siteid = dm.SiteNumber),1,30) DM
            --This is where DM_EMAIL, RM_EMAIL, and SM_EMail originally were before they were removed from both here and .ItemData.
        FROM example.dbo.vInvoiceHeaderDetail_Adis ad
            join example.dbo.Site ss on ad.SiteId=ss.siteid
            join example.dbo.vStoreDistrictRegionActive vs on ad.SiteId = vs.SiteId
        WHERE ad.siteid is not null and UnitNetCore>=250 and SUBSTRING(InvoiceNumber,2,1)='D' and QuantityShipped>0
            and isactive=1 and isowned=1 
            and ShipDate between @Begdate and @Enddate
            and vs.RMFirstName = @RMFirstName
            and vs.RMLastname = @RMLastName

            ORDER BY ad.SiteId,ShipFROMID,shipdate



    -- Execute SSIS package which downloads table to d: for email.  

            set @RecordCount=@@ROWCOUNT

            --Quick check so that if the results were blank, don't bother sending a blank email. 
            IF @RecordCount<>0
                BEGIN

                    set @Subject = 'Cores billed from PWI >= $250 ' + cast(CONVERT(date,GETDATE()) as varchar(12))
                    set @Body    = 'Run date/time- ' + cast(GETDATE() as CHAR(20))

                    EXEC  xp_cmdshell 'd:\"Program Files (x86)"\"Microsoft SQL Server"\100\DTS\Binn\DTexec.exe  /f "D:\etl\bulk\ssis\Misc\ItemInfo.dtsx"'

                    EXEC msdb.dbo.sp_send_dbmail 
                        @profile_name   ='SQL Mail',
                        @recipients     ='test', --@email
                        @subject        = @Subject,
                        @body           = @Body,
                        @body_format    = 'HTML',
                        @File_attachments = 'D:\export\temp\ItemInfo.xls',                
                        @attach_query_result_as_file =0,
                        @query_attachment_filename='\ItemInfo.xls',
                        @query_result_width = 500

                END
        --Brings CURSOR back up to next name on List, repeats process. 
        FETCH NEXT FROM RMListCursor
            INTO @RMLastName
                , @RMFirstName
                , @Email
    END
END

CLOSE RMListCursor
DEALLOCATE RMListCursor

END TRY

BEGIN CATCH

    SET @WarningLevel = 'error'
    SET @MsgDescription = 'SQL Err= [' + CAST(ERROR_MESSAGE() as varchar(200)) + ' (' + CAST(ERROR_LINE() as varchar) + ')]' 
    EXEC example.dbo.spAddSysMessage  'Store Aging', @WarningLevel , @ProcedureName , '',  'EOM Store Aging Report', @RecordCount 

END CATCH


 END

4 个答案:

答案 0 :(得分:6)

重新检查源和目标之间以及中间组件之间的列分配。

尝试将数据流组件的属性,ValidateExternalMetadata设置为False。

请同时查看this

答案 1 :(得分:2)

您最近似乎正在更改OLEDB源或其他类型的源。

因此,您必须删除OLEDB Source并再次创建一个新的。然后还删除特定字段的映射,保存,再次返回映射并将其映射回来。它应该工作得很好。

答案 2 :(得分:0)

我也遇到了同样的问题,即我所有列的名称都相同,但是仍然出现“'excelName'的外部列与数据源列不同步。列“ mycolname” 需要添加到外部列。 列“ F62”需要添加到外部列。” 我也验证了很多时间,但是没有运气,即使我在Excel公式中也将列标题与目标表进行了匹配,而且一切似乎都正确了。所以我逐一手动检查了列,最后发现我使用的文件连接最初的首字母为大写“ Mycolname” ,在我使用的文件(我用来覆盖源文件)的位置上,我只是粘贴了其他文件中的数据,由于我的标题被更改了。我再次更改了标题,但输入文件仍然起作用。

注意:使用SSIS时要小心……非常危险。

答案 3 :(得分:0)

而不是删除和重新创建:

  1. 复制现有数据源。
  2. 将其粘贴回数据流任务。粘贴的数据源具有刷新的架构。您已经保留了任何可能保留的下游映射。您现在面临的维护最少。
  3. 从旧数据源中删除连接器。
  4. 替换新数据源中的连接器。
  5. 如有必要,在数据目标中维护映射。