Oracle
 sql >> Baza danych >  >> RDS >> Oracle

Oracle:ładowanie dużego pliku xml?

Dostęp do plików XML na serwerze można uzyskać za pośrednictwem SQL. Mając swoje dane w /tmp/tmp.xml, najpierw zadeklaruj katalog:

SQL> create directory d as '/tmp';

Directory created

Następnie możesz bezpośrednio zapytać o plik XML:

SQL> SELECT XMLTYPE(bfilename('D', 'tmp.xml'), nls_charset_id('UTF8')) xml_data
  2    FROM dual;

XML_DATA
--------------------------------------------------------------------------------
<?xml version="1.0" encoding="UTF-8"?>
<badges>
  [...]

Aby uzyskać dostęp do pól w swoim pliku, możesz użyć metody opisanej w innym SO, na przykład:

SQL> SELECT UserId, Name, to_timestamp(dt, 'YYYY-MM-DD"T"HH24:MI:SS.FF3') dt
  2    FROM (SELECT XMLTYPE(bfilename('D', 'tmp.xml'), 
                            nls_charset_id('UTF8')) xml_data
  3            FROM dual),
  4         XMLTable('for $i in /badges/row
  5                              return $i'
  6                  passing xml_data
  7                  columns UserId NUMBER path '@UserId',
  8                          Name VARCHAR2(50) path '@Name',
  9                          dt VARCHAR2(25) path '@Date');

    USERID NAME       DT                         
---------- ---------- ---------------------------
      3718 Teacher    2008-09-15 08:55:03.923    
       994 Teacher    2008-09-15 08:55:03.957    


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Sposób na sprawdzenie gotowego sql . Oracle

  2. Udowodnienie równoważności zapytań SQL

  3. Jak usunąć duplikaty z listy rozdzielanej przecinkami według wyrażenia regularnego w Oracle, ale nie chcę duplikatów wartości?

  4. Oracle 12c IDENTYFIKOWANE WARTOŚCIAMI

  5. Jak mogę zrobić wsadowe wstawianie do bazy danych Oracle za pomocą Pythona?