0

无法从数据库中表的列中的 XML 格式选择特定信息。我需要提取 ModuleID 959 的成功消息

提交ID 模块ID 创建于 XMLCOL 更新开
25 959 1-1-22 “请参阅下面的 XML” 1-1-22
26 339 2-1-22 空值 2-1-22

下面是数据库中 XML 列中的数据——我想要实现的是在 SQL 查询中显示第二个 ResultType“成功”。

<ArrayOfActionResult xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <ActionResult>
    <ResultType>Redirected to Payment</ResultType>
    <ActionName>Payment</ActionName>
    <ExecutionTime></ExecutionTime>
    <ConditionSet>
      <Conditions />
      <ExecuteCondition>Always</ExecuteCondition>
      <MatchCondition>All</MatchCondition>
      <ExecuteStatus>0</ExecuteStatus>
      <Groups />
    </ConditionSet>
    <ConditionsMet>true</ConditionsMet>
    <Condition />
  </ActionResult>
  <ActionResult>
    <ResultType>Success</ResultType>
     <ActionName>Payment</ActionName>
    <ExecutionTime></ExecutionTime>
    <ConditionSet>
      <Conditions />
      <ExecuteCondition>Always</ExecuteCondition>
      <MatchCondition>All</MatchCondition>
      <ExecuteStatus>0</ExecuteStatus>
      <Groups />
    </ConditionSet>
    <ConditionsMet>true</ConditionsMet>
  </ActionResult>
</ArrayOfActionResult>

目前我正在尝试使用下面的 SQL 无济于事

SELECT [XMLCOL].value('/ArrayOfActionResult/ActionResult/ResultType[2]') as PaymentMessage
FROM Databasetable
where [ModuleID] = 959

希望这是有道理的,我发现很难解释,我对 SQL 很陌生

4

1 回答 1

3

看看下面。

假设您的数据库是 MS SQL Server。

XQuery.value()方法有两个强制参数。

SQL

-- DDL and sample data population, start
DECLARE @tbl TABLE (ModuleID INT PRIMARY KEY, XMLCOL XML);
INSERT INTO @tbl (ModuleID, XMLCOL) VALUES
(959, N'<ArrayOfActionResult xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
    <ActionResult>
        <ResultType>Redirected to Payment</ResultType>
        <ActionName>Payment</ActionName>
        <ExecutionTime></ExecutionTime>
        <ConditionSet>
            <Conditions/>
            <ExecuteCondition>Always</ExecuteCondition>
            <MatchCondition>All</MatchCondition>
            <ExecuteStatus>0</ExecuteStatus>
            <Groups/>
        </ConditionSet>
        <ConditionsMet>true</ConditionsMet>
        <Condition/>
    </ActionResult>
    <ActionResult>
        <ResultType>Success</ResultType>
        <ActionName>Payment</ActionName>
        <ExecutionTime></ExecutionTime>
        <ConditionSet>
            <Conditions/>
            <ExecuteCondition>Always</ExecuteCondition>
            <MatchCondition>All</MatchCondition>
            <ExecuteStatus>0</ExecuteStatus>
            <Groups/>
        </ConditionSet>
        <ConditionsMet>true</ConditionsMet>
    </ActionResult>
</ArrayOfActionResult>');
-- DDL and sample data population, end

SELECT ModuleID
    , XMLCOL.value('(/ArrayOfActionResult/ActionResult[2]/ResultType/text())[1]','VARCHAR(30)') as PaymentMessage
FROM @tbl
WHERE ModuleID = 959;

输出

+----------+----------------+
| ModuleID | PaymentMessage |
+----------+----------------+
|      959 | Success        |
+----------+----------------+
于 2022-01-24T03:50:40.727 回答