SQL Server 目标
SQL Server 目标连接到本地 SQL Server 数据库,并将数据大容量加载到 SQL Server 表和视图中。 如果包访问远程服务器上的 SQL Server 数据库,则不能在包中使用 SQL Server 目标。 相反,包应使用 OLE DB 目标。 有关详细信息,请参阅 OLE DB Destination。
权限
如果用户所执行的包中包括 SQL Server 目标,则用户需要“创建全局对象”权限。 通过使用从 “管理工具” 菜单打开的本地安全策略工具,可以将此权限授予用户。 如果在执行使用 SQL Server 目标的包时收到错误消息,请确保运行包的帐户拥有“创建全局对象”权限。
大容量插入
如果尝试使用 SQL Server 目标向远程 SQL Server 数据库中大容量加载数据,您将看到如下错误消息:已获得 OLE DB 记录。 源: “Microsoft SQL Server Native Client” Hresult: 0x80040E14 说明:“由于无法打开 SSIS 文件映射对象 ‘Global\DTSQLIMPORT’,无法进行大容量加载。 操作系统错误代码为 2 (系统找不到指定的文件。)。 请确保您是通过 Windows 安全性访问本地服务器的。”
此 SQL Server 目标将数据插入到 SQL Server 中的速度与使用“大容量插入”任务时一样快;但使用 SQL Server 目标可以在数据加载到 SQL Server 中之前,对列数据应用转换。
为了将数据加载到 SQL Server中,应考虑使用 SQL Server 目标而不是 OLE DB 目标。
大容量插入选项
如果 SQL Server 目标使用快速加载数据访问模式,则可以指定下列快速加载选项:
保留导入数据文件的标识值,或使用由 SQL Server分配的唯一值。
在大容量加载操作过程中保留空值。
在大容量导入操作过程中,验证目标表或视图上的约束。
在大容量加载操作期间获取表级锁。
在大容量加载操作过程中,执行对目标表定义的插入触发器。
在大容量插入操作过程中,指定要加载的输入中第一行的行号。
在大容量插入操作过程中,指定要加载的输入中最后一行的行号。
指定在大容量加载操作取消之前允许的最大错误数。 无法导入的每一行将被计为一个错误。
指定输入中包含已排序数据的列。
有关大容量加载选项的详细信息,请参阅 BULK INSERT (Transact-SQL)。
性能改进
若要改善大容量插入的性能和在大容量插入操作过程中对表数据的访问,应对默认选项作如下更改:
在大容量导入操作过程中,不要验证目标表或视图上的约束。
在大容量加载操作过程中,不要执行在目标表上定义的插入触发器。
不要对表应用锁。 这样,其他用户和应用程序在大容量插入操作过程中将可以一直使用该表。
SQL Server 目标的配置
可以使用下列方式配置 SQL Server 目标:
指定要向其大容量加载数据的表或视图。
通过指定如是否检查约束之类的选项,自定义大容量加载操作。
指定是否在一批中提交所有行,或设置在一批中提交的最大行数。
指定大容量加载操作的超时值。
此目标使用 OLE DB 连接管理器连接到数据源,该连接管理器指定要使用的 OLE DB 访问接口。 有关详细信息,请参阅 OLE DB Connection Manager。
Integration Services 项目还提供了创建 OLE DB 连接管理器所用的数据源对象。 这样,SQL Server 目标便可以使用数据源和数据源视图。
SQL Server 目标具有一个输入。 它不支持错误输出。
可以通过 SSIS 设计器或以编程方式来设置属性。
有关在 “SQL Server 目标编辑器” 对话框中可以设置的属性的详细信息,请单击下列主题之一:
“高级编辑器” 对话框反映了可以通过编程方式进行设置的属性。 有关可以在 “高级编辑器” 对话框中或以编程方式设置的属性的详细信息,请单击下列主题之一:
有关如何设置属性的详细信息,请单击下列主题之一:
Related Tasks
相关内容
support.microsoft.com 上的技术文章 您可能会在支持 UAC 的系统上看到“无法准备 SSIS 大容量插入以插入数据”错误。
msdn.microsoft.com 上的技术文章 数据加载性能指南。
simple-talk.com 上的技术文章 使用 SQL Server Integration Services 大容量加载数据。