我创建了一个调用T-SQL文件并将其输出到文本文件的批处理脚本。 T-SQL文件包含表的select语句,以获取以XML作为数据类型的列的信息。然后,该文件将作为电子邮件正文或附件发送。但是,当我打开文本文件时,我会看到一长串类似下面的信息:
<`EVENT_INSTANCE><EventType>CREATE_INDEX</EventType <PostTime>2009-05-29T12:54:28.463...
我期待的是看到内容如下所示:
<EVENT_INSTANCE>
<EventType>CREATE_INDEX</EventType>
<PostTime>2009-05-29T12:54:28.463</PostTime>
<SPID>54</SPID>
<ServerName>SERVER\INSTANCE</ServerName>
<LoginName>Domain\username</LoginName>
<UserName>dbo</UserName>
<DatabaseName>AdventureWorks</DatabaseName>
<SchemaName>dbo</SchemaName>
<ObjectName>ni_ChangeAttempt_DBUser</ObjectName>
<ObjectType>INDEX</ObjectType>
<TargetObjectName>ChangeAttempt</TargetObjectName>
<TargetObjectType>TABLE</TargetObjectType>
<TSQLCommand>
<SetOptions ANSI_NULLS="ON" ANSI_NULL_DEFAULT="ON" ANSI_PADDING="ON" QUOTED_IDENTIFIER="ON" ENCRYPTED="FALSE" />
<CommandText>CREATE NONCLUSTERED INDEX ni_ChangeAttempt_DBUser ON
dbo.ChangeAttempt(DBUser)
</CommandText>
</TSQLCommand>
</EVENT_INSTANCE>
如果上述情况不可行,我希望看到查询的输出如下所示:
Event Post Time Server Name
----- --------- -----------
CREATE INDEX 2009-05-29T12:54:28.463 Server\Instance
我的问题是:发送查询结果的相应输出文件是什么,以便我可以对结果有更有意义和更有条理的视图?
此外:
请参阅以下批处理脚本的内容:
osql -E -S SERVER\INSTANCE -d <database_name> -iD:\scripts\qryddl.sql -oD:\scripts\qryddl01.txt -w2000 -n -h
bmail -s <ip address> -t <email> -f <email> -h -a " Database Object Changes from <ServerName>" -m D:\scripts\qrydll.txt
附加2:
qrydll.sql只有这个内容:
use <database_name>
GO
SELECT EventData FROM dbo.ChangeAttempt
表dbo.ChangeAttempt具有以下结构:
Column Name Data Type
----------- ---------
EvenData xml
AttemptDate datetime
DBUser char(50)
答案 0 :(得分:1)
你所缺少的只是空格,空格与真正的xml无关。无论哪种阅读都会以同样的方式对待它。