sql >> Database >  >> RDS >> Oracle

XML-import naar Oracle met SQL Developer

U probeert twee kolommen van een subquery bij te werken, maar uw syntaxis is verkeerd; het zou meer moeten zijn als:

update tablename set (col1 = val1, col2 = val2)
select (val1, val 2 from ...)

In jouw geval zoiets als dit, ervan uitgaande dat je dezelfde tabel invoegt en bijwerkt, en de (aangepaste) onbewerkte XML doorgeeft als een SQL*Plus var voor mijn testen:

create table spectraexchange(sv_sv_id varchar2(15), ss_ss_id varchar2(15),
    ap_name varchar2(15), ap_prj_ident varchar2(15),
    tcs_name varchar2(15), tcs_call varchar2(15));

Table created.

insert into spectraexchange(sv_sv_id, ss_ss_id, ap_name, ap_prj_ident)
select extractvalue(value(x), 'APPLICATION/SV_SV_ID') sv_sv_id,
    extractvalue(value(x), 'APPLICATION/SS_SS_ID') ss_ss_id,
    extractvalue(value(x), 'APPLICATION/AP_NAME') ap_name,
    extractvalue(value(x), 'APPLICATION/AP_PRJ_IDENT') ap_prj_ident
from (
    select xmltype(:raw_xml) xmlcol from dual
) t
cross join table(XMLSequence(extract(t.xmlcol,
    '/SPECTRAEXCHANGE/APPLICATION'))) x;

1 row created.

select * from spectraexchange;

SV_SV_ID        SS_SS_ID        AP_NAME         AP_PRJ_IDENT    TCS_NAME        TCS_CALL
--------------- --------------- --------------- --------------- --------------- ---------------
kClong          kClong          kCstring (64)   kCstring (32)

Dan zou de update kunnen zijn:

update spectraexchange
set (tcs_name, tcs_call) = (
    select extractvalue(value(x), 'STATION/TCS_NAME'),
        extractvalue(value(x), 'STATION/TCS_CALL')
    from (
        select xmltype(:raw_xml) xmlcol from dual
    ) t
    cross join table(XMLSequence(extract(t.xmlcol,
        '/SPECTRAEXCHANGE/APPLICATION/STATION'))) x
);

1 row updated.

select * from spectraexchange;

SV_SV_ID        SS_SS_ID        AP_NAME         AP_PRJ_IDENT    TCS_NAME        TCS_CALL
--------------- --------------- --------------- --------------- --------------- ---------------
kClong          kClong          kCstring (64)   kCstring (32)   kCstring (64)   kCstring (256)

Als dit natuurlijk ook uitgaat van één station per applicatie, anders heb je meerdere samengevoegde tabellen nodig om de relaties vast te houden, denk ik; en slechts één applicatie of uw update zou op de een of andere manier gecorreleerd moeten zijn. Maar dan lijkt de update zinloos, je zou het allemaal op insert kunnen doen:

insert into spectraexchange(sv_sv_id, ss_ss_id, ap_name, ap_prj_ident,
    tcs_name, tcs_call)
select extractvalue(value(x), 'APPLICATION/SV_SV_ID') sv_sv_id,
    extractvalue(value(x), 'APPLICATION/SS_SS_ID') ss_ss_id,
    extractvalue(value(x), 'APPLICATION/AP_NAME') ap_name,
    extractvalue(value(x), 'APPLICATION/AP_PRJ_IDENT') ap_prj_ident,
    extractvalue(value(x), 'APPLICATION/STATION/TCS_NAME') tcs_name,
    extractvalue(value(x), 'APPLICATION/STATION/TCS_CALL') tcs_call
from (
    select xmltype(:raw_xml) xmlcol from dual
) t
cross join table(XMLSequence(extract(t.xmlcol,
    '/SPECTRAEXCHANGE/APPLICATION'))) x;

... (wat alleen werkt met één-op-één relaties) dus ik mis duidelijk iets op de foto.

Op basis van uw opmerkingen dat u een-op-veel-relaties heeft en u alles in één tabel invoegt (!?), kunt u in plaats daarvan dit doen:

insert into spectra exchange ( ... columns ... )
select a.sv_sv_id, a.ss_ss_id, a.ap_name, a.ap_prj_ident,
    s.tcs_name, s.tcs_call,
    t.eqp_equip_name, t.eqp_equip_type
from (select xmltype(:raw_xml) xmlcol from dual) r
cross join xmltable('/SPECTRAEXCHANGE/APPLICATION' passing r.xmlcol
        columns sv_sv_id varchar2(15) path 'SV_SV_ID',
            ss_ss_id varchar2(15) path 'SS_SS_ID',
            ap_name varchar2(15) path 'AP_NAME',
            ap_prj_ident varchar2(15) path 'AP_PRJ_IDENT',
            stations xmltype path 'STATION'
    ) (+) a
cross join xmltable('/STATION' passing a.stations
        columns tcs_name varchar2(15) path 'TCS_NAME',
            tcs_call varchar2(15) path 'TCS_CALL',
            transmitter xmltype path 'TRANSMITTER'
    ) (+) s
cross join xmltable('/TRANSMITTER' passing s.transmitter
        columns eqp_equip_name varchar2(15) path 'EQP_EQUIP_NAME',
            eqp_equip_type varchar2(15) path 'EQP_EQUIP_TYPE',
            frequency xmltype path 'FREQUENCY'
    ) (+) t
/

Ik ben een extra niveau naar de zender gegaan en je kunt het patroon gewoon herhalen om meer toe te voegen, waarbij je elke keer het relevante knooppunt doorgeeft. De buitenste sluit zich aan (+) zal toestaan ​​voor sommige dingen die niet bestaan, b.v. als je een zender hebt die nog geen frequentie heeft gekregen, of wat dan ook, dan krijg je een nul in de relevante kolommen.




  1. MySQL-query INNER JOIN met aliassen

  2. Wat moet ik gebruiken in plaats van volgorde om hiaten te voorkomen?

  3. Heroku Rails 4 kon geen verbinding maken met de server:verbinding geweigerd

  4. Detecteer opeenvolgende datumbereiken met behulp van SQL