sql – 使用SSIS包加载数据时理解间歇性不一致的问题
栏目: 数据库 · SQL Server · 发布时间: 5年前
内容简介:问题在过去的几个月中,下面描述的程序在其运行的绝大部分时间内都没有任何问题(2008年r2).但是,我们有三个错误连接数据的实例.问题是,造成这种情况的原因是什么以及如何解决这个问题?通常,渲染结果是属性正确连接到Items_Main,但有时(小于1%)订单被加扰,因此col01的值没有连接到与其余列的值相同的Items_Main.
问题
在过去的几个月中,下面描述的程序在其运行的绝大部分时间内都没有任何问题(2008年r2).但是,我们有三个错误连接数据的实例.问题是,造成这种情况的原因是什么以及如何解决这个问题?
DATA_PreImp sourceid col01 col02 col03 col04 col... 100001 John Smith 100002 Calvin Klein 100003 Peter Parker 100004 Moe Greene
通常,渲染结果是属性正确连接到Items_Main,但有时(小于1%)订单被加扰,因此col01的值没有连接到与其余列的值相同的Items_Main.
任何有关造成这种情况的见解都将是最受欢迎的.
数据移动程序
我们有一个SSIS包,它将数据从名为DATA_PreImp的平面表传输到由三个相关表组成的结构(基于属性).
> Items_Main应包含DATA_PreImp中每行的一行
> Items_Featurevalues包含DATA_PreImp中每行的每个列值的一行
> Items_MainRel包含Items_Main和Items_FeatureValues之间的连接
SSIS包中的第一步将DATA_PreImp中的数据插入到Items_Main中,并将生成的标识符插入到空DATA_PreImpMappingTMP表的TARGET_ID列中.
insert into items_main(creationdate, status) output inserted.itemid into DATA_PreImpMappingTMP(TARGET_ID) select getdate(), '0' from data_preimp order by sourceid asc;
SSIS包中的第二步使用TARGET_ID(最初为Itemid)填充Items_MainRel表,并使用该功能的标识符(在本例中为5).
insert into items_mainrel(itemid, featureid) output inserted.itemrelid into DATA_PreImpMapping2TMP(INDREL_ID) select TARGET_ID, 5 from DATA_PreImpMappingTMP order by TARGET_ID asc;
第三步是使用DATA_PreImp中的SOURCE_ID填充DATA_PreImpMapping2TMP表中的SOURCE_ID列.
with cte as (select sourceid, row_number() over (order by sourceid asc) as row from data_preimp) update m set m.SOURCE_ID = s.sourceid, m.FEAT_ID = 5 from DATA_PreImpMapping2TMP as m join cte as s on s.row = m.ROW;
最后一步是使用DATA_PreImpMapping2TMP和DATA_PreImp中的数据填充Items_FeatureValues表.
insert into items_featurevalues(itemrelid, languageid, fnvarchar) select DATA_PreImpMapping2TMP.INDREL_ID, 0, data_preimp.col01 from DATA_PreImpMapping2TMP join data_preimp on (DATA_PreImpMapping2TMP.SOURCE_ID = data_preimp.sourceid) where FEAT_ID = 5
数据表结构
以下是创建场景所需的内容:
CREATE TABLE [dbo].[DATA_PreImp]( [sourceid] [bigint] IDENTITY(1,1) NOT NULL, [col01] [nvarchar](500) NULL, [col02] [nvarchar](500) NULL, [col03] [nvarchar](500) NULL, [col04] [nvarchar](500) NULL, [col05] [nvarchar](500) NULL, [col06] [nvarchar](500) NULL, [col07] [nvarchar](500) NULL, [col08] [nvarchar](500) NULL, [col09] [nvarchar](500) NULL, [col10] [nvarchar](500) NULL, CONSTRAINT [PK_DATA_PreImp] PRIMARY KEY CLUSTERED ( [sourceid] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY] CREATE TABLE [dbo].[DATA_PreImpMappingTMP]( [ROW] [int] IDENTITY(1,1) NOT NULL, [TARGET_ID] [int] NULL, PRIMARY KEY CLUSTERED ( [ROW] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY] CREATE TABLE [dbo].[Items_Main]( [Itemid] [int] IDENTITY(1,1) NOT NULL, [creationDate] [smalldatetime] NOT NULL, [status] [int] NOT NULL, [purchdate] [smalldatetime] NULL, [logindate] [smalldatetime] NULL, CONSTRAINT [PK_Items_Main] PRIMARY KEY CLUSTERED ( [Itemid] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY] CREATE TABLE [dbo].[DATA_PreImpMapping2TMP]( [ROW] [int] IDENTITY(1,1) NOT NULL, [SOURCE_ID] [int] NULL, [INDREL_ID] [int] NULL, [FEAT_ID] [int] NULL, PRIMARY KEY CLUSTERED ( [ROW] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY] CREATE TABLE [dbo].[Items_Features]( [featureId] [int] IDENTITY(1,1) NOT NULL, [featureRef] [varchar](15) NOT NULL, [featureName] [varchar](50) NOT NULL, [creationDate] [smalldatetime] NOT NULL, [status] [int] NOT NULL, [fieldType] [varchar](50) NOT NULL, [featureType] [int] NOT NULL, [featureDesc] [varchar](500) NULL, CONSTRAINT [PK_Items_Features] PRIMARY KEY CLUSTERED ( [featureId] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]) ON [PRIMARY] CREATE TABLE [dbo].[Items_MainRel]( [ItemRelId] [int] IDENTITY(1,1) NOT NULL, [Itemid] [int] NOT NULL, [featureId] [int] NOT NULL, CONSTRAINT [PK_Items_MainRel] PRIMARY KEY CLUSTERED ( [ItemRelId] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY] GO CREATE TABLE [dbo].[Items_FeatureValues]( [valueId] [int] IDENTITY(1,1) NOT NULL, [ItemRelId] [int] NOT NULL, [languageId] [int] NOT NULL, [FnVarChar] [nvarchar](250) NULL, [FInt] [int] NULL, [FImage] [int] NULL, [FNText] [ntext] NULL, [FSmallDateTime] [smalldatetime] NULL, CONSTRAINT [PK_Items_FeatureValues] PRIMARY KEY CLUSTERED ( [valueId] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY] GO ALTER TABLE [dbo].[Items_MainRel] WITH CHECK ADD CONSTRAINT [FK_Items_MainRel_Items_Features] FOREIGN KEY([featureId]) REFERENCES [dbo].[Items_Features] ([featureId]) GO ALTER TABLE [dbo].[Items_MainRel] CHECK CONSTRAINT [FK_Items_MainRel_Items_Features] GO ALTER TABLE [dbo].[Items_MainRel] WITH CHECK ADD CONSTRAINT [FK_Items_MainRel_Items_Main] FOREIGN KEY([Itemid]) REFERENCES [dbo].[Items_Main] ([Itemid]) GO ALTER TABLE [dbo].[Items_MainRel] CHECK CONSTRAINT [FK_Items_MainRel_Items_Main] GO ALTER TABLE [dbo].[Items_FeatureValues] WITH CHECK ADD CONSTRAINT [FK_Items_FeatureValues_Items_MainRel] FOREIGN KEY([ItemRelId]) REFERENCES [dbo].[Items_MainRel] ([ItemRelId]) ON DELETE CASCADE GO ALTER TABLE [dbo].[Items_FeatureValues] CHECK CONSTRAINT [FK_Items_FeatureValues_Items_MainRel] GO INSERT INTO DATA_PreImp (col01,col02,col03,col04) VALUES('John', 'Smith', '1964', 'NewYork'), ('Calvin', 'Klein', '1960', 'Washington D. C.'), ('Peter', 'Parker', '1974', 'Losangles'), ('Moe', 'Greene', '1928', 'Lasvegas') INSERT INTO Items_Features (featureRef, featureName, creationDate, [status], fieldType, featureType, featureDesc) VALUES ('firstname','First_Name', GETDATE(), 0, 'FnVarChar', 3, 'FirstName'), ('lastname','Last_Name', GETDATE(), 0, 'FnVarChar', 3, 'LastName'), ('Birth','Birth', GETDATE(), 0, 'FnVarChar', 3, 'Birth'), ('City','City', GETDATE(), 0, 'FnVarChar', 3, 'City')
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
《数据结构》算法实现及解析
高一凡 / 西安电子科技大学出版社 / 2002-10-1 / 35.0
《数据结构算法实现及解析》配有光盘,光盘中包括书中所有程序及用标准C语言改写的程序。所有程序均在计算机上运行通过。《数据结构算法实现及解析》适用于使用教科书的大中专学生和自学者。书中的基本操作函数也可供从事计算机工程与应用工作的科技人员参考和采用。一起来看看 《《数据结构》算法实现及解析》 这本书的介绍吧!