大容量导入和导出数据 -- 介绍
SQL Server 支持从 SQL Server 表大容量导出数据以及将大容量数据导入 SQL Server 表或未分区的视图。 大容量导入和大容量导出对在 SQL Server 和异类数据源之间有效传输数据是非常重要的。
“大容量导出”是指将数据从 SQL Server 表复制到数据文件。
“大容量导入”是指将数据从数据文件加载到 SQL Server 表。
例如,您可以将数据从 Microsoft Excel 应用程序导出到数据文件,然后将这些数据大容量导入到 SQL Server 表中。
大容量导入和导出数据的方法
可以使用下列基本方法:
方法 |
说明 |
导入数据 |
导出数据 |
bcp 实用工具 |
大容量导出数据和大容量导入数据并生成格式化文件的命令行实用工具 (Bcp.exe)。 |
支持 |
支持 |
BULK INSERT 语句 |
将数据直接从数据文件导入数据库表或未分区视图的 Transact-SQL 语句。 |
支持 |
不支持 |
INSERT ... SELECT * FROM OPENROWSET(BULK...) 语句 |
通过在 INSERT 语句中指定 OPENROWSET(BULK…) 函数来选择数据,从而使用 OPENROWSET 大容量行集提供程序将数据大容量导入 SQL Server 表的 Transact-SQL 语句。 |
支持 |
不支持 |
格式化文件
bcp 实用工具、BULK INSERT 和 INSERT ... SELECT * FROM OPENROWSET(BULK...) 都支持使用专门的“格式化文件”来存储数据文件中每个字段的格式信息。 格式化文件还可以包含相应的 SQL Server 表的有关信息。 格式化文件可以用于提供从 SQL Server 实例大容量导出数据和向其中大容量导入数据时所需的所有格式信息。
格式化文件提供了一种解释导入期间数据文件中数据的格式以及设置导出期间数据文件中数据格式的灵活方式。 这种灵活性使得解释数据时无需编写专用代码,也无需为满足 SQL Server 或外部应用程序的特殊需要而重新设置数据的格式。 例如,如果将要加载的数据大容量导出到某个需要逗号分隔值的应用程序,则可以使用格式化文件将逗号作为字段终止符插入导出的数据中。
SQL Server 支持两种格式化文件:XML 格式化文件和非 XML 格式化文件。
bcp 实用工具是唯一能够生成格式化文件的工具。
准备用于SQL Server大容量导出或导入的数据要求
对于SQL Server大容量导出或导入的数据在格式上是有要求的,详细可参见MSDN的具体说明:
https://msdn.microsoft.com/zh-cn/library/ms188609.aspx