BIML GetDropAndCreateDdl为数据类型创建不正确的长度

时间:2016-04-06 20:18:22

标签: tsql biml

当我使用GetDropAndCreateDdl为表生成CREATE脚本时,我得到的数据类型与数据类型实际不同的列不同。

这会导致程序包验证错误“错误输出具有与其相应数据源列的属性不匹配的属性”,并且验证状态为“VS_NEEDSNEWMETADATA”。

如果我右键单击连接源,选择Show Advanced Editor,看看Column Mappings,我可以看到Available External Columns列表中的[Column1]与生成的数据类型的长度不同GetDropAndCreateDdl。我可以删除并重新创建元数据映射,但这不是一个可行的解决方案,因为有许多数据流任务。

如何让GetDropAndCreateDdl创建正确长度的正确数据类型?

我正在使用ImportDB来获取表,元数据等列表

Environment.biml

<Biml xmlns="http://schemas.varigence.com/biml.xsd">
    <Connections>
        <OdbcConnection Name="OdbcSrc_DV" ConnectionString="Dsn=Source-32bit-test;" />
        <OleDbConnection Name="OleDbDst_Staging" ConnectionString="Provider=SQLNCLI11;Server=SQL-DEV;Initial Catalog=Source_Staging;Integrated Security=SSPI;" />
    </Connections>
    <Databases>
        <Database Name="Source" ConnectionName="OdbcSrc_DV" />
        <Database Name="Source_Staging" ConnectionName="OleDbDst_Staging" />
    </Databases>
    <Schemas>
        <Schema Name="dbo" DatabaseName="Source" />
        <Schema Name="dbo" DatabaseName="Source_Staging" />
    </Schemas>
</Biml>

CreateTableMetadata.biml

<#@ import namespace="System.Data" #>
<#@ import namespace="Varigence.Biml.CoreLowerer.SchemaManagement"  #>
<#
var sourceConnection = RootNode.DbConnections["OdbcSrc_DV"];
var importResult = sourceConnection.ImportDB("", "", ImportOptions.ExcludeForeignKey | ImportOptions.ExcludeColumnDefault | ImportOptions.ExcludeViews);

var tableNamesToImport = new List<string>() { "Test_Table" };
#>
<Biml xmlns="http://schemas.varigence.com/biml.xsd">
  <Tables>

    <# foreach (var table in importResult.TableNodes.Where(item => tableNamesToImport.Contains(item.Name)).OrderBy(item => item.Name)) { #>

    <Table Name="<#=table.Name#>" SchemaName="Source.dbo">
      <Columns>
            <#=table.Columns.GetBiml()#>
      </Columns>
      <Annotations>
        <Annotation AnnotationType="Tag" Tag="SourceSchemaQualifiedName"><#=table.SchemaQualifiedName#></Annotation>
      </Annotations>
    </Table>
    <# } #>
  </Tables>
</Biml>

DeployTargetTables.biml

<#@ template tier="2" #>
<Biml xmlns="http://schemas.varigence.com/biml.xsd">
  <Packages>
    <Package Name="MasterTableDeploy" ConstraintMode="Parallel">
      <Tasks>
        <# foreach (var table in RootNode.Tables) { #>

        <ExecuteSQL Name="SQL CREATE <#=table.Name#>" ConnectionName="OleDbDst_Staging">
          <DirectInput><#=table.GetDropAndCreateDdl()#></DirectInput>
        </ExecuteSQL>
        <# } #>
      </Tasks>
    </Package>
  </Packages>
</Biml>

CreateLoadPackages.biml

<#@ template tier="2" #>
<Biml xmlns="http://schemas.varigence.com/biml.xsd">
  <Packages>
    <Package Name="Copy Data" ConstraintMode="Parallel">

      <Tasks>
        <# foreach (var table in RootNode.Tables) { #>
        <ExecuteSQL Name="SQL TRUNCATE <#=table.Name#>" ConnectionName="OleDbDst_Staging">
          <DirectInput>TRUNCATE TABLE <#=table.Name#></DirectInput>
        </ExecuteSQL>
        <Dataflow Name="DFT LOAD <#=table.Schema.Name#>_<#=table.Name#>">
            <PrecedenceConstraints>
                <Inputs>
                    <Input OutputPathName="SQL TRUNCATE <#=table.Name#>.Output" />
                </Inputs>
            </PrecedenceConstraints>
          <Transformations>

              <OdbcSource Name="ODBC_SRC <#=table.Name#>" Connection="OdbcSrc_DV">
              <DirectInput>SELECT <#=table.GetColumnList()#> FROM <#=table.GetTag("SourceSchemaQualifiedName")#></DirectInput>
              </OdbcSource>

            <OleDbDestination Name="ODBC_DST <#=table.Name#>" ConnectionName="OleDbDst_Staging">
              <TableOutput TableName="<#=table.ScopedName#>" />
            </OleDbDestination>
          </Transformations>
        </Dataflow>
          <# } #>
      </Tasks>
    </Package>
  </Packages>
</Biml>

以下是从ODBC源创建的脚本 -

enter image description here

以下是来自INFORMATION_SCHEMA.COLUMNS的相同表格的结果 -

enter image description here

1 个答案:

答案 0 :(得分:1)

您是否尝试过使用较新的方法:GetDatabaseSchema?我发现它在不同的连接类型中更加可靠。

http://www.cathrinewilhelmsen.net/2015/07/12/biml-extension-methods-getdatabaseschema/