1

我试图使用 BCP 将数据从 CDC 函数转储到 .dat 文件中。我使用以下查询(适用于 Server 2008 R2):

USE LEESWIJZER

DECLARE @begin_time datetime
, @end_time datetime
, @from_lsn binary(10)
, @to_lsn binary(10)

SET @end_time = '2013-07-05 12:00:00.000';    

SELECT @to_lsn = sys.fn_cdc_map_time_to_lsn('largest less than or equal',  @end_time);
SELECT @from_lsn = sys.fn_cdc_get_min_lsn('dbo_LWR_CONTRIBUTIES')

SELECT sys.fn_cdc_map_lsn_to_time(__$start_lsn) AS ChangeDTS
, *
FROM cdc.fn_cdc_get_net_changes_dbo_LWR_CONTRIBUTIES (@from_lsn, @to_LSN, 'all')

(为便于阅读而编辑,在 BCP 中用作单个字符串)

我的 BCP 字符串是:

BCP "Query above" queryout "C:\temp\LWRCONTRIBUTIES.dat" -w -t ";|" -r \n -T -S {server\\instance} -o "C:\temp\LWRCONTRIBUTIES.log"

如您所见,我想要一个生成的 .dat unicode 文件和一个日志文件。我猜添加到函数结果中的“ChangeDTS”列导致了我的问题。错误消息显示:“[Microsoft][SQL Native Client]Host-file 列可能仅在复制到服务器时被跳过”。

它可以使用格式文件解决,但由于此代码需要每天运行,可能一天不止一次,并且表格可能会发生变化,我不愿意不断调整我的格式文件(有 100 个表格需要相同的程序)。

此外,这是在客户数据库上运行的,他们不会喜欢我在他们的数据库中创建视图。

有人知道如何从 cdc 函数中创建一个包含选定列数的文本文件 (.dat) 吗?

4

1 回答 1

1

找到了答案,无论使用哪个版本的 bcp,bcp 似乎都无法处理声明。如果我把它们编辑掉,就像一个魅力。但是,根据另一个论坛上的某人的说法,BCP 应该是处理变量的声明。很高兴它现在对我有用,但仍然困惑为什么它现在和以前没有。

于 2012-08-13T07:56:22.340 回答