排序转换

排序转换按升序或降序对输入数据进行排序,并将排序后的数据复制到转换输出。您可以对一个输入应用多个排序;每个排序都由确定排序顺序的一个数字来标识。首先对具有最小数字的列进行排序,然后对具有第二小数字的排序列进行排序,依此类推。例如,如果名为 CountryRegion 的列的排序顺序为 1,而名为 City 的列的排序顺序为 2,则输出先按照 country/region(国家/地区)排序,然后按照 city(城市)排序。正数表示排序为升序排序,负数表示排序为降序排序。不进行排序的列的排序顺序为 0。没有选择进行排序的列将与被排序列一起自动被复制到转换输出。

排序转换包含一组比较选项,这些选项可以定义转换处理列中字符串数据的方式。有关详细信息,请参阅比较字符串数据

注意注意

排序转换对 GUID 进行排序的顺序不同于 ORDER BY 子句在 Transact-SQL 中对其排序的顺序。排序转换先对以 0-9 开头的 GUID 进行排序,然后再对以 A-F 开头的 GUID 进行排序,而 ORDER BY 子句对 GUID 进行排序的顺序则不同于此,这在 SQL Server 数据库引擎中得到了体现。有关详细信息,请参阅 ORDER BY 子句 (Transact-SQL)

作为排序操作的一部分,排序转换还可删除重复行。重复行是具有相同排序键值的行。排序键值是根据所用的字符串比较选项生成的,这意味着不同文字字符串可能具有相同的排序键值。转换将输入列中具有不同值但具有相同排序键的行标识为重复行。

排序转换包括了可以在加载包时通过属性表达式进行更新的 MaximumThreads 自定义属性。有关详细信息,请参阅 Integration Services 表达式参考在包中使用属性表达式转换自定义属性

此转换有一个输入和一个输出。它不支持错误输出。

配置排序转换

可以通过 SSIS 设计器或以编程方式来设置属性。

有关可在**“排序转换编辑器”**对话框中设置的属性的详细信息,请参阅排序转换编辑器

**“高级编辑器”对话框反映了可以通过编程方式进行设置的属性。有关可以在“高级编辑器”**对话框中或以编程方式设置的属性的详细信息,请单击下列主题之一:

有关如何设置属性的详细信息,请参阅如何设置数据流组件的属性

外部资源

codeplex.com 上的示例 SortDeDuplicateDelimitedString 自定义 SSIS 组件

Integration Services 图标(小) 使 Integration Services 保持最新

若要从 Microsoft 获得最新的下载内容、文章、示例和视频,以及从社区获得所选解决方案,请访问 MSDN 或 TechNet 上的 Integration Services 页:

若要获得有关这些更新的自动通知,请订阅该页上提供的 RSS 源。