繁体   English   中英

使用VBScript将记录集转换为XML

[英]Getting the recordset into an XML using VBScript

我的SQL查询返回实际上是XML的单列结果。 当我单击记录集时,它会打开一个results.xml

这是我使用抓取到result_string的输出XML

result_string = objRecordSet.Fields(colname).Value
<TEST_SUITE SUITE_ID="122675741" PART_NUMBER="MTSTE-26248-00" REVISION="A"     SUITE_TYPE="PRODUCTION" SUITE_NAME="HOT-LOW" SUITE_STOP_ON_FAIL="TRUE" TARGET_DURATION="0" SEQUENCE="1" UPDATED="2016-12-15T00:21:46.510">
  <SUITE_DESCRIPTION>"HOT-LOW"</SUITE_DESCRIPTION>
  <TESTS>
    <TEST TEST_ID="122663528" TEST_NAME="Set Suite Environment Variables" PART_NUMBER="MTTST-65899-00" REVISION="A" MODULE="TEST Set Environment Variables.vi" MODULE_LIBRARY="BIG-IP_TESTS" TEST_STOP_ON_FAIL="TRUE"   TEST_TYPE="BEGIN_SESSION">
      <PARAMETERS>
        <PARAMETER PARAMETER_ID="122663469" PARAMETER_NAME="TOS" PARAMETER_VALUE="build_2.0.1.1647.0_centos6_x86_64" />
        <PARAMETER PARAMETER_ID="82137" PARAMETER_NAME="chain" PARAMETER_VALUE="TRUE" />
      </PARAMETERS>
      <MEASUREMENTS>
        <MEASUREMENT MEASUREMENT_ID="70784" MEASUREMENT_NAME="TOS" UNITS="" UPPER_LIMIT="" LOWER_LIMIT="" COMPARISON="LOG" INPUT_SCALE_FACTOR="" OUTPUT_SCALE_FACTOR="" />
        <MEASUREMENT MEASUREMENT_ID="81537" MEASUREMENT_NAME="chain" UNITS="" UPPER_LIMIT="" LOWER_LIMIT="" COMPARISON="LOG" INPUT_SCALE_FACTOR="" OUTPUT_SCALE_FACTOR="" />
      </MEASUREMENTS>
    </TEST>
  </TESTS>
</TEST_SUITE>

为此,我需要一个Test_ID。 我如何将这个result_string存储到XML result_string并获得Test_ID。 还是有任何简单的方法来获取Test_ID?

我做了类似的事情,但是不确定这是否正确,而且在objCommand.Execute ,, adExecuteStream行上也出现错误。

Dim strm  
Set strm = CreateObject("ADODB.Stream")

strm.Open

Set objCommand.ActiveConnection = objConnection
objCommand.CommandText = script_testID
objCommand.Properties("Output Stream")= strm
objCommand.Properties("Output Encoding") = "UTF-8"
objCommand.Properties("XML Root") = "Root"  'this can be anything you want

objCommand.CommandType = 4
objCommand.Execute ,, adExecuteStream
strm.Position = 0
text = strm.ReadText
Set xmlDoc = CreateObject("Microsoft.XMLDOM")
xmlDoc.Async = "false"

xmlDoc.LoadXML(strm.ReadText)
strm.Close : Set strm = Nothing
Set objCommand = Nothing

您已经在解析XML数据,因此可以像这样轻松提取值:

...
xmlDoc.LoadXML(strm.ReadText)

test_id = xmlDoc.SelectSingleNode("//TEST/@TEST_ID").Value
...

我建议使用Msxml2.DOMDocument而不是不推荐使用的Microsoft.XMLDOM ,并且我还建议在处理数据之前检查解析错误:

...
Set xmlDoc = CreateObject("Msxml2.DOMDocument.6.0")
xmlDoc.Async = False
xmlDoc.LoadXML strm.ReadText

If xmlDoc.ParseError <> 0 Then
    WScript.Echo xmlDoc.ParseError.Reason
    WScript.Quit 1
End If

test_id = xmlDoc.SelectSingleNode("//TEST/@TEST_ID").Value
...

请注意, XPath表达式//TEST/@TEST_ID )区分大小写。

test_id = Split(Split(result_string, "TEST_ID=""", 2)(1), """", 2)(0)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM