我正在尝试使用BIML和Visual 2008创建一个FuzzyLookup对象。
以下代码错误并没有使用错误进行编译,“无法解析对dbo.JuniorSurveyResponses的引用”。对象dbo.JuniorSurveyResponses存在,我对它有正确的权限。
如果删除FuzzyLookup,则创建代码的其余部分,编译时不会出错。这段代码实际上来自https://www.varigence.com/Documentation/Samples/Biml/Fuzzy+Lookup。
对这个错误有什么想法吗?
<Biml xmlns="http://schemas.varigence.com/biml.xsd">
<Connections>
<OleDbConnection Name="SportsData" ConnectionString="Provider=SQLNCLI10;Server=myServer;Initial Catalog=myCatalog;Integrated Security=SSPI;" DelayValidation="true" />
</Connections>
<Packages>
<Package Name="My Package" ConstraintMode="Linear">
<Tasks>
<Dataflow Name="My Dataflow Task">
<Transformations>
<OleDbSource Name="SurveyResponses" ConnectionName="SportsData">
<DirectInput>select * from SurveyResponses</DirectInput>
</OleDbSource>
<!-- Performs a fuzzy lookup on the Attribute column against the JuniorSurveyResponse DB, and outputs the corresponding Response column to NewResponse. -->
<FuzzyLookup Name="Fuzzy Lookup Transformation" ConnectionName="SportsData" Exhaustive="true" >
<ReferenceTableInput TableName="dbo.JuniorSurveyResponses" />
<Inputs>
<Column SourceColumn="Attribute" TargetColumn="Attribute" />
</Inputs>
<Outputs>
<Column SourceColumn="Response" TargetColumn="NewReponse" />
</Outputs>
<InputPath OutputPathName="SurveyResponses.Output" />
</FuzzyLookup>
<FlatFileDestination Name="OutputFile" ConnectionName="FlatFileConnection" Overwrite="true" />
</Transformations>
</Dataflow>
</Tasks>
</Package>
</Packages>
</Biml>发布于 2014-01-31 18:05:08
我认为varigence.com引用的示例的问题在于它使用的是ReferenceTableInput。我相信这意味着它需要在您的项目中定义一个<Tables>集合以及所有这些好东西。
相反,我认为您正在寻找一个语法为ExternalReferenceTableInput的
<ExternalReferenceTableInput Table="dbo.JuniorSurveyResponses" />使用它作为我的源,我创建了下面的模糊查找。

如果模糊查找不应该是这样的话,请告诉我。尽管我大量使用SSIS,但我从未使用该转换。
对于那些在家里跟随的人,我在我的源系统中创建了两个表,
CREATE TABLE dbo.JuniorSurveyResponses
(
Attribute varchar(50)
, Response varchar(50)
);
CREATE TABLE dbo.SurveyResponses
(
Attribute varchar(50)
, Response varchar(50)
);https://stackoverflow.com/questions/21483735
复制相似问题