0

我编写了以下过程来使用 openxml 进行批量插入。在我的情况下,表名和列名是动态的,因为它们将在下面插入之前从 .Net 应用程序创建。存储过程运行成功,但未向表中插入任何数据。

请帮我

预先感谢。

CREATE PROCEDURE [dbo].[BulkUpdate]
@XmlDoc text,
@TableName nvarchar(50),
@ColumnNames nvarchar(4000),
@ColumnDefinition nvarchar(4000)
AS
BEGIN
-- SET NOCOUNT ON added to prevent extra result sets from
-- interfering with SELECT statements.
SET NOCOUNT ON;
Declare @Idoc int;
Declare @Sql nvarchar(4000);
BEGIN TRANSACTION
Begin Try
Exec sp_xml_preparedocument @Idoc output, @XmlDoc;

Set @Sql = 'Insert into '+@TableName+'('+@ColumnNames+')

Select '+@ColumnNames+' From OpenXML(@Idoc,''/NewDataSet/Data'', 2)

With('+@ColumnDefinition+')';

Print @sql;
Exec @Sql;

Exec sp_xml_removedocument @Idoc;
Commit Transaction
End Try
Begin Catch
RollBack Transaction
End Catch

END
4

1 回答 1

0

我观察到 SqlClient.BulkCopy 比上述 OpenXML 方法性能更好。因此我相应地改变了我的逻辑。

于 2012-12-17T19:12:30.403 回答