sql server 中XML太长 提取时数据丢失 解决????

songguozhi 2010-04-14 05:17:53

create proc xxxx
@doc ntext=NULL
as
begin
declare @idoc int
--declare @pre table(t ntext)
--declare @doc varchar(8000)
set @doc='
<upd:Update xmlns:pub="http://schemas.microsoft.com/msus/2002/12/Publishing"
xmlns:msp="http://schemas.microsoft.com/msus/2002/12/UpdateHandlers/WindowsInstaller"
xmlns:mar="http://schemas.microsoft.com/msus/2002/12/MsiApplicabilityRules"
xmlns:mspblob="http://www.microsoft.com/msi/patch_applicability.xsd"
xmlns:upd="http://schemas.microsoft.com/msus/2002/12/Update">
<!--PUID[513870]Name[MSCTF_8022_INTL]-->
<upd:UpdateIdentity UpdateID="ff096040-4f3c-478d-9a85-03edfd9920fc" RevisionNumber="100"/>
<upd:Properties UpdateType="Software" DefaultPropertiesLanguage="en" Handler="http://schemas.microsoft.com/msus/2002/12/UpdateHandlers/WindowsInstaller" PublicationState="Published" CreationDate="2006-05-05T20:55:13.009Z" PublisherID="9b068e57-8e2d-4e42-b091-74bdb345f120" MaxDownloadSize="1736295" MinDownloadSize="0">
<upd:InstallationBehavior RebootBehavior="CanRequestReboot"/>
</upd:Properties>
<upd:LocalizedPropertiesCollection>
<upd:LocalizedProperties>
<upd:Language>en</upd:Language>
<upd:Title>MSCTF_8022_INTL</upd:Title>
</upd:LocalizedProperties>
</upd:LocalizedPropertiesCollection>
<upd:Relationships>
<upd:Prerequisites>
<upd:UpdateIdentity UpdateID="1403f223-a63f-f572-82ba-c92391218055"/>
<upd:UpdateIdentity UpdateID="3B4B8621-726E-43A6-B43B-37D07EC7019F"/>
</upd:Prerequisites>
</upd:Relationships>
<upd:ApplicabilityRules>
<upd:IsInstalled>
<mar:MsiPatchInstalled xmlns:mar="http://schemas.microsoft.com/msus/2002/12/MsiApplicabilityRules"/>
</upd:IsInstalled>
<upd:IsSuperseded>
<mar:MsiPatchSuperseded xmlns:mar="http://schemas.microsoft.com/msus/2002/12/MsiApplicabilityRules"/>
</upd:IsSuperseded>
<upd:IsInstallable>
<mar:MsiPatchInstallable xmlns:mar="http://schemas.microsoft.com/msus/2002/12/MsiApplicabilityRules"/>
</upd:IsInstallable>
<upd:Metadata>
<mar:MsiPatchMetadata xmlns:mar="http://schemas.microsoft.com/msus/2002/12/MsiApplicabilityRules">
<MsiPatch xmlns="http://www.microsoft.com/msi/patch_applicability.xsd" SchemaVersion="1.0.0.0" PatchGUID="{8BE3C22E-85D7-41EB-8D4E-1053DBA17575}" MinMsiVersion="3">
<TargetProduct MinMsiVersion="100">
<TargetProductCode Validate="true">{901F040C-6000-11D3-8CFE-0150048383C9}</TargetProductCode>
<TargetVersion Validate="false" ComparisonType="None" ComparisonFilter="None">11.0.5614.0</TargetVersion>
<TargetLanguage Validate="false">1036</TargetLanguage>
<UpdatedLanguages>1036</UpdatedLanguages>
<UpgradeCode Validate="false">{001F0000-6000-11D3-8CFE-0050048383C9}</UpgradeCode>
</TargetProduct>
<TargetProduct MinMsiVersion="100">
<TargetProductCode Validate="true">{901F0C0A-6000-11D3-8CFE-0150048383C9}</TargetProductCode>
<TargetVersion Validate="false" ComparisonType="None" ComparisonFilter="None">11.0.5614.1</TargetVersion>
<TargetLanguage Validate="false">3082</TargetLanguage>
<UpdatedLanguages>3082</UpdatedLanguages>
<UpgradeCode Validate="false">{001F0000-6000-11D3-8CFE-0050048383C9}</UpgradeCode>
</TargetProduct>
<TargetProductCode>{91A10C0A-6000-11D3-8CFE-0150048383C9}</TargetProductCode>
<TargetProductCode>{91A10407-6000-11D3-8CFE-0150048383C9}</TargetProductCode>
<TargetProductCode>{90FD0411-6000-11D3-8CFE-0150048383C9}</TargetProductCode>
<TargetProductCode>{90E30409-6000-11D3-8CFE-0150048383C9}</TargetProductCode>
<ObsoletedPatch>{525CE135-97D5-4D3F-A168-BA9E4EADEA0A}</ObsoletedPatch>
<ObsoletedPatch>{3597A0F7-B55A-4762-BE7A-7E6B70CE577D}</ObsoletedPatch>
<ObsoletedPatch>{0FE25E55-5C81-418F-9E1E-FDDEE4BCBA9B}</ObsoletedPatch>
<SequenceData>
<PatchFamily>msctf</PatchFamily>
<Sequence>8022</Sequence>
<Attributes>1</Attributes>
</SequenceData>
</MsiPatch>
</mar:MsiPatchMetadata>
</upd:Metadata>
</upd:ApplicabilityRules>
<upd:Files>
<upd:File Digest="Kx3h3mp6ep1160kPLBjS+RRJJiU=" DigestAlgorithm="SHA1" FileName="MSCTF.CAB" Size="1736295" Modified="2006-05-03T17:44:00.8400000-07:00" PatchingType="SelfContained"/>
</upd:Files>
<upd:HandlerSpecificData xmlns:pub="http://schemas.microsoft.com/msus/2002/12/Publishing" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="msp:WindowsInstaller">
<msp:MspData xmlns:msp="http://schemas.microsoft.com/msus/2002/12/UpdateHandlers/WindowsInstaller" CommandLine="DISABLESRCPROMPT=1 LOCALCACHESRCRES=0 NOLOCALCACHEROLLBACK=1" UninstallCommandLine="DISABLESRCPROMPT=1 LOCALCACHESRCRES=0 NOLOCALCACHEROLLBACK=1" FullFilePatchCode="{8be3c22e-85d7-41eb-8d4e-1053dba17575}"/>
</upd:HandlerSpecificData>
</upd:Update>
'


EXEC sp_xml_preparedocument @idoc OUTPUT, @doc , '<q xmlns:upd="http://schemas.microsoft.com/msus/2002/12/Update"
xmlns:pub="http://schemas.microsoft.com/msus/2002/12/Publishing"
xmlns:msp="http://schemas.microsoft.com/msus/2002/12/UpdateHandlers/WindowsInstaller"
xmlns:mar="http://schemas.microsoft.com/msus/2002/12/MsiApplicabilityRules"
xmlns:mspblob="http://www.microsoft.com/msi/patch_applicability.xsd"/>'


SELECT xmltext FROM OPENXML (@idoc, '/upd:Update/upd:ApplicabilityRules')
WITH(xmltext ntext '@mp:xmltext')

SELECT xmltext FROM OPENXML (@idoc, '/upd:Update/upd:Files')
WITH(xmltext ntext '@mp:xmltext')

EXEC sp_xml_removedocument @idoc
end
go
exec xxxx
go
drop proc xxxx




由于帖子字符数量限制,没有将源文件内容全部贴出来,如果哪位需要,发邮件到250614049@qq.com,我会在5分钟内将源文件发出来
ApplicabilityRules无法获取,我发现是因为太长,我试着删除一部分,再提取则可以提取成功;
同时我也采用了query方法,但是一样的会丢失,无法获取数据;

哪位有类似问题经验的请赐教一下!!!!
...全文
34689 9 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
--小F-- 2010-04-19
  • 打赏
  • 举报
回复
2005以上能不能将XML保存到VARCHAR(MAX)字段中去?
songguozhi 2010-04-19
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 garnett_kg 的回复:]
恐怕不是xml丢失了,而是SELECT 返回的长度有限制.

你可以试试将select的结果存至一个table,然后export到一个excel档,再看看结果对不对.
[/Quote]

如何解决???????????????????????
Garnett_KG 2010-04-15
  • 打赏
  • 举报
回复
恐怕不是xml丢失了,而是SELECT 返回的长度有限制.

你可以试试将select的结果存至一个table,然后export到一个excel档,再看看结果对不对.
songguozhi 2010-04-15
  • 打赏
  • 举报
回复
期待啊……………………………………………………
jwwyqs 2010-04-14
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 fredrickhu 的回复:]
不懂XML 帮顶
[/Quote]
up
htl258_Tony 2010-04-14
  • 打赏
  • 举报
回复
create proc xxxx
@doc varchar(max)=NULL
as
改为这样呢?
--小F-- 2010-04-14
  • 打赏
  • 举报
回复
不懂XML 帮顶
budong0000 2010-04-14
  • 打赏
  • 举报
回复
以前也遇到长字符串,后来就用拼接了, 比如:

declare @s varchar(max)
set @s = '.&*^)#*(LJRJEKHRUIE..........'
set @s += 'lsfjsdiofsdfdfs'
set @s += 'lsfjsdiofsdfdfs'
支持 MS SQL 2005 之前的版本 不支持 sql 2008 介绍 Log Explorer主要用于对MSSQLServer的事物分析和数据恢复。你可以浏览日志、导出数据、恢复被修改或者删除的数据(包括执行过update,delete,drop和truncate语句的表格)。一旦由于系统故障或者人为因素导致数据丢失,它能够提供在线快速的数据恢复,最大程度上保证恢复期间的其他事物不间断执行。 他可以支持SQLServer7.0、SQLServer2000和SQLServer2005,提取标准数据库的日志文件或者备份文件的信息。 其提供两个强大的工具:日志分析浏览,对象恢复。具体功能如下: l 日志文件浏览 l 数据库变更审查 l 计划和授权变更审查 l 将日志记录导出到文件或者数据库表 l 实监控数据库事物 l 计算并统计负荷 l 通过有选择性的取消或者重做事物来恢复数据 l 恢复被截断或者删除表数据 l 运行SQL脚本 产品 LogExplore包含两部分 l 客户端软件 l 服务器代理 服务器端代理是保存在SQLServer主机的一个只读存储过程,他的作用是接受客户端请求,读取在线事物日志块并通过网络传给客户端软件,由客户端软件来读取这些原始的数据块来完成Log Explore所提供的所有功能。 他依赖来的网络协议包括: l Named Pipe:局域网适用 l Tcp/Ip:广域网适用 数据库相关介绍 事物日志(Transaction Log) SQLServer的每个数据库都包含事物日志,它以文件的形式存储,可以记录数据库的任何变化。发生故障SQLServer就是通过它来保证数据的完整性。 操作(Operation) 操作是数据定义的"原子行为",每个操作都在日志文件保存为一条记录。它可以是用户直接输入的SQL语句,比如标准的insert命令,日志文件便会记录一条操作代码来标志这个insert操作。 事物(Transaction) 事物是一系列操作组成的序列。他可以理解为直观的不可分割的一笔业务,可以执行成功或者失败。典型的事物比如由应用程序发出的具有开启-提交功能的一组SQL语句。不同的事物靠事物Id号(transaction ID)来区分,具有相同ID的事物记录的日志也相同。 在线事物日志(Online Transaction Log) 在线事物日志是指当前活动数据库所用的日志。可以通过如下命令来确定其对应文件 Select * from SYSFILES 他的文件后缀名一般是.LDF 离线事物日志(Offline Transaction Log) 离线事物日志是指非活动数据库所用的日志。当其数据库处于关闭(ShutDown)才状态下可以进行复制备份操作。他的结果同在线事物日志完全相同。 备份文件 备份文件是保存食物日志备份的文件,通常管理员通过运行SQL语句或者企业管理器来生成该文件。备份文件的内部结构和事物日志不同,他采用称为MTF的格式来保存数据。一个备份文件可以包含一个日志的多组备份,甚至包括多个数据库的混合备份. 设置为自动收缩 企业管理器--服务器--右键数据库--属性--选项--选择"自动收缩" 强烈要求该项不要选.否则SQLServer将已循环的方式来覆盖先前的日志记录,将会导致LogExplore无法恢复错误. 数据恢复介绍 LogExplore允许你恢复应为误操作或者程序错误而导致的数据丢失或者更改.比如执行update\Delete语句丢失了where子句,或者错误使用了Dts功能. LogExplore不支持直接修改数据库.他可以生成事物的逆操作脚本. 如果log是delete table where ...的话,生成的文件代码就是insert table .... 你可以通过SQL查询分析器,或者LogExplore的Run SQL Script功能来执行生成脚本. 关于Undo Undo功能可以逆操作一组指定的用户事物。包括insert,delete和update,其局限性如下: l 事物类别:LogExplore只能undo用户事物。用户事物是指在用户表上定义的事物,不支持系统表的更新恢复。同,他也不支持计划变更的回滚。 l Blob类型:包括text,ntext,image类型。LogExplore只支持这些类型的insert和delete恢复,不支持update语句恢复。 关于redo Redo功能可以再次运行一组指定事物。它可以在以下情况用到: 丢失数据库而且没有任何备份文件。 l 如果原始日志文件没有丢失可以通过Redo来实现恢复。 l

22,302

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧