繁体   English   中英

SQL SERVER 上的 SqlBulkCopy 标识

[英]SqlBulkCopy Identity on SQL SERVER

我尝试使用 SqlBulkCopy 插入到数据库,但问题是当 Sql 服务器上的 id 为 identity(1,1) 时,我收到此错误“无法将 NULL 值插入列 'two', 表 'mydb.dbo.test'; 列没有不允许空值。插入失败。”

string connString = string.Format("Data Source={0};Initial Catalog={1};Integrated Security=True",DbServer,databaseName);
            DataTable table = new DataTable("test");
            //table.Columns.Add("id");
            table.Columns.Add("one", typeof(int));
            table.Columns.Add("two", typeof(int));

            DataRow row = table.NewRow();
            row["one"] = 1;
            row["two"] = 2;
            table.Rows.Add(row);

            DataRow row2 = table.NewRow();
            row2["one"] = 1;
            row2["two"] = 2;
            table.Rows.Add(row2);

            SqlBulkCopy bulk = new SqlBulkCopy(connString);
            bulk.DestinationTableName = "test";

            try
            {

                bulk.WriteToServer(table);
                bulk.Close();
            }
            catch (Exception ex)
            {
                Console.WriteLine("error. {0}", ex.Message);
            }
            finally
            {
                bulk.Close();
            }

编辑表方案:

SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

CREATE TABLE [dbo].[test](
    [id] [INT] IDENTITY(1,1) NOT NULL,
    [one] [INT] NOT NULL,
    [two] [INT] NOT NULL,
 CONSTRAINT [PK_test] PRIMARY KEY CLUSTERED 
(
    [id] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
GO

如果您的本地表定义与服务器的(缺少标识列)不匹配,则您需要为每一列添加显式映射(区分大小写)

第一个值是本地源列的名称,第二个值是目标列名称。

bulk.ColumnMappings.Add("one", "one");
bulk.ColumnMappings.Add("two", "two");

如果名称不完全匹配,情况也是如此。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM