从SQLServer2008中提取RTF

从SQLServer2008中提取RTF,sql,sql-server-2008,rtf,bcp,Sql,Sql Server 2008,Rtf,Bcp,我有一个专栏,我想摘录,但有问题!该列存储为ntext类型,并包含RTF文档,因此如下所示: {\rtf1\ansi\ansicpg1252\uc1\deff0{\fonttbl {\f0\fnil\fcharset0\fprq2 Arial;} {\f1\fswiss\fcharset0\fprq2 Arial;} {\f2\froman\fcharset2\fprq2 Symbol;}} {\colortbl;\red0\green0\blue0;\red255\green255\b

我有一个专栏,我想摘录,但有问题!该列存储为ntext类型,并包含RTF文档,因此如下所示:

{\rtf1\ansi\ansicpg1252\uc1\deff0{\fonttbl  {\f0\fnil\fcharset0\fprq2 Arial;}  {\f1\fswiss\fcharset0\fprq2 Arial;}  {\f2\froman\fcharset2\fprq2 Symbol;}}  {\colortbl;\red0\green0\blue0;\red255\green255\blue255;}  {\stylesheet{\s0\itap0\nowidctlpar\f0\fs24 [Normal];}{\*\cs10\additive Default Paragraph Font;}}  {\*\generator TX_RTF32 15.0.530.502;}  \deftab1134\paperw11909\paperh16834\margl1138\margt1138\margr1138\margb1138\widowctrl\formshade\sectd  \headery720\footery720\pgwsxn11909\pghsxn16834\marglsxn1134\margtsxn1134\margrsxn1134\margbsxn1134\pard\itap0\nowidctlpar\plain\f1\fs20 Stephan Bos  28/11/2011 11:19:55\par\par Sold in guy. He likes him, feedback this afternoon.\par Will send him the CV and also our terms.\par Made him aware of our fees.\par }
但我希望将其提取回(rtf或txt,我并不介意) 我尝试过使用BCP,它成功地提取了文档,但结果与列完全相同,但每个字符之间都有空格,而不是我预期的那样(上面的示例将阅读如下内容:

Stephan Bos  28/11/2011 11:19:55
Sold in guy. He likes him, feedback this afternoon.
Will send him the CV and also our terms.
Made him aware of our fees.
我正在使用的BCP摘录(正在提取)如下所示:

set nocount on;
Declare @sql varchar(1000);
declare @noteid int;
declare xx1 cursor for select nic.NotebookItemId from NotebookItemContent nic
inner join NotebookLinks nl on nl.NotebookItemId = nic.NotebookItemId
inner join NotebookItems ni on ni.NotebookItemId = nic.NotebookItemId
where nl.clientid = 1235074
AND ni.NotebookTypeId = 56;
open xx1;
fetch xx1 into @noteid;
while (@@fetch_status = 0)
begin
set @sql = 'BCP "SELECT memo FROM Monarch_Pronet_ITOIL.dbo.notebookitemcontent where notebookitemid=' + cast(@noteid as varchar) + 
'" QUERYOUT \\bhamws475\docs\' + cast(@noteid as varchar) + '.rtf -T -f \\bhamws475\docs\bcp.fmt -S ' + @@SERVERNAME
EXEC master.dbo.xp_CmdShell @sql
fetch xx1 into @noteid;
end;
close xx1;
deallocate xx1;

有人能给我指出正确的方向吗?

我想我现在明白了-问题是BCP保存的RTF不能被Word识别为RTF文件-它是以纯文本文件打开的

这是因为导出的文件是Unicode格式的(您可以看到,屏幕截图中每个字符后面都有一个空格)


解决方案是告诉bcp不要用Unicode保存—我认为这可以通过
-c
开关或在格式文件中指定所需的字符集来完成。

因此,问题是输出中没有结束行(只有一个大行)?我想说,当您导入数据时,它们不知怎的丢失了。如果您在SQL查询窗口中执行
select memo from…
,将输出设置为文本,您是否只看到一行或多行?我已拍摄了问题的屏幕截图-这应该提供一些细节!抱歉,我不知道屏幕截图显示的是哪个问题。如果你试着按照我上面的建议去做,你看到多行了吗?(假设这就是问题所在)