У меня есть XML, показанный ниже:
<element type="PRICE_SPECIFIC_SIMPLE_QUERY">
<query>
<and>
<match field="product" value="Bottle"/>
<not>
<match field="status" value="Cancel"/>
</not>
<not>
<match field="material">
<value>GLASS</value>
<value>METAL</value>
</match>
</not>
<greaterThan field="LastDateToPrice" value="2017-12-20"/>
<match field="company" value="MILTON"/>
</and>
</query>
</element>
С XPath = /element[@type='PRICE_SPECIFIC_SIMPLE_QUERY' мне нужен внутренний XML как String... как показано ниже:
<query>
<and>
<match field="product" value="Bottle"/>
<not>
<match field="status" value="Cancel"/>
</not>
<not>
<match field="material">
<value>GLASS</value>
<value>METAL</value>
</match>
</not>
<greaterThan field="LastDateToPrice" value="2017-12-20"/>
<match field="company" value="MILTON"/>
</and>
</query>
Но с примерами, доступными в Интернете, я получаю внутренние значения, но не XML. Мой пример кода показан ниже:
XPathFactory xpathFactory = XPathFactory.newInstance();
XPath xpath = xpathFactory.newXPath();
String queryType = "ICE_SPECIFIC_SIMPLE_QUERY";
XPathExpression expr = xpath.compile("/element[@type='" + queryType + "']");
String innerElement = (String) expr.evaluate(doc, XPathConstants.STRING);
Фактический результат: СТЕКЛО\n МЕТАЛЛ