在大容量导入期间保留 Null 值或使用默认值
默认情况下,将数据导入表中时,bcp 命令和 BULK INSERT 语句将使用为表中的列定义的默认值。例如,如果数据文件中包含一个空字段,则就会加载该列的默认值。bcp 命令和 BULK INSERT 语句都允许指定保留空值。
相反,常规 INSERT 语句会保留空值而不会插入默认值。INSERT ... SELECT * FROM OPENROWSET(BULK...)语句的基本行为与常规 INSERT 相同,但前者还支持插入默认值的表提示。
 注意 | 
|---|
有关跳过表列的示例格式化文件,请参阅使用格式化文件跳过表列。  | 
示例表和数据文件
若要运行本主题中的示例,需要创建示例表和数据文件。
示例表
这些示例要求在 AdventureWorks2008R2 示例数据库中的 dbo 架构下创建名为 MyTestDefaultCol2 的表。若要创建此表,请在 Microsoft SQL Server Management Studio 查询编辑器中执行以下语句:
USE AdventureWorks2008R2;
GO
CREATE TABLE MyTestDefaultCol2 
(Col1 smallint,
Col2 nvarchar(50) DEFAULT 'Default value of Col2',
Col3 nvarchar(50) 
);
GO
注意,第二个表列 (Col2) 具有默认值。
示例格式化文件
某些大容量导入示例使用非 XML 格式化文件 MyTestDefaultCol2-f-c.Fmt,它与 MyTestDefaultCol2 表完全一致。若要创建此格式化文件,请在 Microsoft Windows 命令提示符下输入:
bcp AdventureWorks2008R2..MyTestDefaultCol2 format nul -c -f C:\MyTestDefaultCol2-f-c.Fmt -t, -r\n -T
有关创建格式化文件的详细信息,请参阅创建格式化文件。
示例数据文件
该示例使用示例数据文件 MyTestEmptyField2-c.Dat,它的第二个字段中不包含值。MyTestEmptyField2-c.Dat 数据文件包含下列记录。
1,,DataField3
2,,DataField3
使 bcp 或 BULK INSERT 保留空值
下列限定符指定在大容量导入操作期间数据文件中的空字段保留其空值,而不继承表列的默认值(如果存在)。
命令  | 
限定符  | 
限定符类型  | 
|---|---|---|
bcp  | 
-k  | 
开关  | 
BULK INSERT  | 
KEEPNULLS1  | 
参数  | 
1 对于 BULK INSERT,如果默认值不可用,则必须将表列定义为允许空值。
 注意 | 
|---|
这些限定符通过这些大容量导入命令禁止检查表上的 DEFAULT 定义。然而,对于任何并发 INSERT 语句,都需要 DEFAULT 定义。  | 
有关详细信息,请参阅 bcp 实用工具和 BULK INSERT (Transact-SQL)。
示例
本节中的示例使用 bcp 或 BULK INSERT 进行大容量导入并保留空值。
第二个表列 Col2 具有默认值。数据文件的相应字段包含空字符串。默认情况下,当 bcp 或 BULK INSERT 用于将数据从此数据文件导入 MyTestDefaultCol2 表时,将插入 Col2 的默认值,这会产生下列结果:
1  | 
Default value of Col2  | 
DataField3  | 
2  | 
Default value of Col2  | 
DataField3  | 
若要插入“NULL”(而不是“Default value of Col2”),需要使用 -k 开关或 KEEPNULL 选项(如下列 bcp 和 BULK INSERT 示例所示)。
使用 bcp 并保留空值
下列示例演示如何在 bcp 命令中保留空值。bcp 命令包含以下开关:
开关  | 
说明  | 
|---|---|
-f  | 
指定命令使用格式化文件。  | 
-k  | 
指定在操作过程中空列应该保留空值,而不是所插入列的任何默认值。  | 
-T  | 
指定 bcp 实用工具使用可信连接来连接到 SQL Server。  | 
在 Windows 命令提示符下输入。
bcp AdventureWorks2008R2..MyTestDefaultCol2 in C:\MyTestEmptyField2-c.Dat -f C:\MyTestDefaultCol2-f-c.Fmt -k -T
使用 BULK INSERT 并保留空值
下面的示例演示如何使用 BULK INSERT 语句中的 KEEPNULLS 选项。在查询工具(如 SQL Server Management Studio 查询编辑器)中执行以下语句:
USE AdventureWorks2008R2;
GO
BULK INSERT MyTestDefaultCol2
   FROM 'C:\MyTestEmptyField2-c.Dat'
   WITH (
      DATAFILETYPE = 'char',
      FIELDTERMINATOR = ',',
      KEEPNULLS
   );
GO
使用 INSERT ... SELECT * FROM OPENROWSET(BULK...)
默认情况下,未在大容量加载操作中指定的所有列都被 INSERT ... SELECT * FROM OPENROWSET(BULK...) 设置为 NULL。但是,对于数据文件中的空字段,您可以指定相应的表列使用其默认值(如果存在)。若要使用默认值,请指定下列表提示:
命令  | 
限定符  | 
限定符类型  | 
|---|---|---|
INSERT ... SELECT * FROM OPENROWSET(BULK...)  | 
WITH(KEEPDEFAULTS)  | 
表提示  | 
 注意 | 
|---|
有关详细信息,请参阅 INSERT (Transact-SQL)、SELECT (Transact-SQL)、OPENROWSET (Transact-SQL) 和表提示 (Transact-SQL)  | 
示例
下列 INSERT ... SELECT * FROM OPENROWSET(BULK...)示例将大容量导入数据并保留默认值。
若要运行这些示例,需要创建 MyTestDefaultCol2 示例表和 MyTestEmptyField2-c.Dat 数据文件,并使用格式化文件 MyTestDefaultCol2-f-c.Fmt。有关创建这些示例的信息,请参阅本主题前面的“示例表和数据文件”。
第二个表列 Col2 具有默认值。数据文件的相应字段包含空字符串。当 INSERT ... SELECT * FROM OPENROWSET(BULK...)将该数据文件中的字段导入 MyTestDefaultCol2 表时,默认情况下,NULL(而不是默认值)将被插入到 Col2 中。此默认的行为产生下列结果:
1  | 
NULL  | 
DataField3  | 
2  | 
NULL  | 
DataField3  | 
若要插入默认值“Default value of Col2”代替“NULL”,需要使用 KEEPDEFAULTS 表提示,如下面的示例所示。在查询工具(如 SQL Server Management Studio 查询编辑器)中执行以下语句:
USE AdventureWorks2008R2;
GO
INSERT INTO MyTestDefaultCol2
    WITH (KEEPDEFAULTS)
    SELECT *
      FROM OPENROWSET(BULK  'C:\MyTestEmptyField2-c.Dat',
      FORMATFILE='C:\MyTestDefaultCol2-f-c.Fmt'     
      ) as t1 ;
GO
注意