możesz zrób to za pomocą extractvalue
:
select extractvalue(
xmltype(response_string),
'/soap:Envelope/soap:Body/getAddressForIpResponse/p-address',
'xmlns="urn:USR1" xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"')
from dual;
ale extractvalue
jest przestarzałe
; więc powinieneś użyć XMLQuery
:
select XMLQuery(
'declare default element namespace "urn:USR1";
declare namespace soap="http://schemas.xmlsoap.org/soap/envelope/";
/soap:Envelope/soap:Body/getAddressForIpResponse/p-address/text()'
passing xmltype(response_string)
returning content).getStringval()
from dual;
Tak czy inaczej, musisz podać domyślne i soap
przestrzenie nazw.
Możesz również użyć XMLTable, jeśli wyodrębniasz wiele bitów danych; tutaj niewiele to dodaje, ale byłoby to coś takiego:
select ip_address
from XMLTable (
XMLNamespaces (
default 'urn:USR1',
'http://schemas.xmlsoap.org/soap/envelope/' as "soap"
),
'/soap:Envelope/soap:Body/getAddressForIpResponse/p-address'
passing xmltype(response_string)
columns ip_address varchar2(15) path '.');