导入来自早期版本的 SQL Server 的本机格式数据和字符格式数据Import native and character format data from earlier versions of SQL Server

适用对象:是SQL Server 是Azure SQL 数据库 是Azure Synapse Analytics (SQL DW) 是并行数据仓库 APPLIES TO: yesSQL Server yesAzure SQL Database yesAzure Synapse Analytics (SQL DW) yesParallel Data Warehouse

SQL Server 2019 (15.x)SQL Server 2019 (15.x)中,可以通过将 bcpSQL Server 2000 (8.x)SQL Server 2000 (8.x)-V SQL Server 2005 (9.x)SQL Server 2005 (9.x)开关一起使用,从 SQL Server 2008SQL Server 2008SQL Server 2008 R2SQL Server 2008 R2SQL Server 2012 (11.x)SQL Server 2012 (11.x) 中导入本机和字符格式数据。In SQL Server 2019 (15.x)SQL Server 2019 (15.x), you can use bcp to import native and character format data from SQL Server 2000 (8.x)SQL Server 2000 (8.x), SQL Server 2005 (9.x)SQL Server 2005 (9.x), SQL Server 2008SQL Server 2008, SQL Server 2008 R2SQL Server 2008 R2, or SQL Server 2012 (11.x)SQL Server 2012 (11.x) by using the -V switch. -V 开关将使 SQL Server 2019 (15.x)SQL Server 2019 (15.x) 使用指定的 SQL ServerSQL Server早期版本中的数据类型,并且数据文件格式与早期版本中的格式相同。The -V switch causes SQL Server 2019 (15.x)SQL Server 2019 (15.x) to use data types from the specified earlier version of SQL ServerSQL Server, and the data file format are the same as the format in that earlier version.

若要为数据文件指定 SQL ServerSQL Server 早期版本,可将 -V 开关与以下的任一限定符一起使用:To specify an earlier SQL ServerSQL Server version for a data file, use the -V switch with one of the following qualifiers:

SQL Server 版本SQL Server version QualifierQualifier
SQL Server 2000 (8.x)SQL Server 2000 (8.x) -V80-V80
SQL Server 2005 (9.x)SQL Server 2005 (9.x) -V90-V90
SQL Server 2008SQL Server 2008 -V100-V100
SQL Server 2012 (11.x)SQL Server 2012 (11.x) -V 110-V 110

对数据类型的解释Interpretation of Data Types

SQL Server 2005 (9.x)SQL Server 2005 (9.x) 及更高版本均支持一些新的类型。and later versions have support for some new types. 如果要将新的数据类型导入到 SQL ServerSQL Server 早期版本中,则必须以早期的 bcp 客户端可读的格式存储该数据类型。When you want to import a new data type into an earlier SQL ServerSQL Server version, the data type must be stored in a format that readable by the older bcp clients. 下表总结了如何转换新数据类型以便与早期版本的 SQL ServerSQL Server兼容。The following table summarizes how the new data types are converted for compatibility with the earlier versions of SQL ServerSQL Server.

SQL Server 2005 中的新数据类型New data types in SQL Server 2005 版本 6x兼容的数据类型Compatible data types in version 6x 版本 70 中兼容的数据类型Compatible data types in version 70 版本 80 中兼容的数据类型Compatible data types in version 80
bigintbigint decimaldecimal decimaldecimal *
sql_variantsql_variant texttext nvarchar(4000)nvarchar(4000) *
varchar(max)varchar(max) texttext texttext texttext
nvarchar(max)nvarchar(max) ntextntext ntextntext ntextntext
varbinary(max)varbinary(max) 图像image 图像image 图像image
XMLXML ntextntext ntextntext ntextntext
UDT**UDT** 图像image 图像image 图像image

*此类型受本机支持。*This type is natively supported.

**UDT 表示用户定义的类型。**UDT indicates a user defined type.

使用 -V 80 进行导出Exporting using -V 80

使用 -V80 开关批量导出数据时,本机模式下的 nvarchar(max)、varchar(max)、varbinary(max)、XML 和 UDT 数据将像 text、image 和 ntext 数据一样以带有 4 个字节的前缀形式存储,而不是像 SQL Server 2005 (9.x)SQL Server 2005 (9.x) 及更高版本默认的那样以带有 8 个字节的前缀形式存储 。When you bulk export data by using the -V80 switch, nvarchar(max), varchar(max), varbinary(max), XML, and UDT data in native mode are stored with a 4-byte prefix, like text, image, and ntext data, rather than with an 8-byte prefix, which is the default for SQL Server 2005 (9.x)SQL Server 2005 (9.x) and later versions.

复制日期值Copying Date Values

bcp 将使用 ODBC 大容量复制 API。bcp uses the ODBC bulk copy API. 因此,为了将日期值导入到 SQL ServerSQL Server中, bcp 使用了 ODBC 日期格式 (yyyy-mm-dd hh:mm:ss[ .f... ])。Therefore, to import date values into SQL ServerSQL Server, bcp uses the ODBC date format (yyyy-mm-dd hh:mm:ss[.f...]).

对于字符格式的数据文件, bcp 命令会为 datetimesmalldatetime 类型的值使用 ODBC 默认格式将文件导出。The bcp command exports character format data files using the ODBC default format for datetime and smalldatetime values. 例如,包含日期 datetime 12 Aug 1998 列将以字符串 1998-08-12 00:00:00.000的形式大容量复制到数据文件中。For example, a datetime column containing the date 12 Aug 1998 is bulk copied to a data file as the character string 1998-08-12 00:00:00.000.

重要

在使用 bcp 将数据导入到 smalldatetime字段中时,请确保秒数值为 00.000,否则操作将失败。When importing data into a smalldatetime field using bcp, be sure the value for seconds is 00.000; otherwise the operation will fail. smalldatetime 数据类型仅支持最接近的分钟值。The smalldatetime data type only holds values to the nearest minute. BULK INSERT 和 INSERT ...SELECT * FROM OPENROWSET(BULK...) 在这种情况下不会失败,但会截断秒值。BULK INSERT and INSERT ... SELECT * FROM OPENROWSET(BULK...) will not fail in this instance but will truncate the seconds value.

相关任务Related Tasks

使用数据格式进行大容量导入或大容量导出To use data formats for bulk import or bulk export

另请参阅See Also

bcp Utility bcp Utility
BULK INSERT (Transact-SQL) BULK INSERT (Transact-SQL)
OPENROWSET (Transact-SQL) OPENROWSET (Transact-SQL)
数据类型 (Transact-SQL) Data Types (Transact-SQL)
SQL Server 数据库引擎的向后兼容性 SQL Server Database Engine Backward Compatibility
CAST 和 CONVERT (Transact-SQL)CAST and CONVERT (Transact-SQL)