[英]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.