SQL Server 2005 BULK INSERT 的提交计数

发布于 2024-11-19 14:23:19 字数 272 浏览 3 评论 0原文

我使用带有 BATCHSIZE 选项的批量插入。 当 BULK INSERT 处理失败时,如何获取提交计数。 例如:

BEGIN TRY
    BULK INSERT t1 FROM "C:\temp\temp.dat" WITH(BATCHSIZE=1000)
END TRY
BEGIN CATCH
    PRINT CONVERT(VARCHAR, @@rowcount)
END CATCH

@@rowcount 返回 0

I use BULK INSERT WITH BATCHSIZE OPTION.
How can I Get Committed Count When the BULK INSERT fail in processing.
like:

BEGIN TRY
    BULK INSERT t1 FROM "C:\temp\temp.dat" WITH(BATCHSIZE=1000)
END TRY
BEGIN CATCH
    PRINT CONVERT(VARCHAR, @@rowcount)
END CATCH

the @@rowcount returned 0

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

つ低調成傷 2024-11-26 14:23:20

您可以首先将表行数计入变量中。

DECLARE @cntBefore bigint;
SELECT @cntBefore = COUNT(*) FROM t1;
BEGIN TRY
    BULK INSERT t1 FROM "C:\temp\temp.dat" WITH(BATCHSIZE=1000)
END TRY
BEGIN CATCH
    DECLARE @cntAfter bigint;
    SELECT @cntAfter = COUNT(*) FROM t1;
    PRINT 'Imported ' + CONVERT(VARCHAR, @cntAfter-@cntBefore)
END CATCH

或者,使用ROWS_PER_BATCH来优化导入,然后所有行都将回滚。

You could count the table rows first into a variable.

DECLARE @cntBefore bigint;
SELECT @cntBefore = COUNT(*) FROM t1;
BEGIN TRY
    BULK INSERT t1 FROM "C:\temp\temp.dat" WITH(BATCHSIZE=1000)
END TRY
BEGIN CATCH
    DECLARE @cntAfter bigint;
    SELECT @cntAfter = COUNT(*) FROM t1;
    PRINT 'Imported ' + CONVERT(VARCHAR, @cntAfter-@cntBefore)
END CATCH

Alternatively, use ROWS_PER_BATCH to optimise the import, then all the rows will be rolled back.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文